Symmetry Theory in Molecular Physics with Mathematica
William Martin McClain
Symmetry Theory in Molecular Physics with Mathematica A new kind of tutorial book
123
William Martin McClain Department of Chemistry Wayne State University 5101 Cass Avenue Detroit MI 48202 USA wmm@chem.wayne.edu
ISBN 978-0-387-73469-9 e-ISBN 978-0-387-73470-5 DOI 10.1007/b13137 Springer Dordrecht Heidelberg London New York Library of Congress Control Number: 2009933284 c Springer Science+Business Media, LLC 2009 All rights reserved. This work may not be translated or copied in whole or in part without the written permission of the publisher (Springer Science+Business Media, LLC, 233 Spring Street, New York, NY 10013, USA), except for brief excerpts in connection with reviews or scholarly analysis. Use in connection with any form of information storage and retrieval, electronic adaptation, computer software, or by similar or dissimilar methodology now known or hereafter developed is forbidden. The use in this publication of trade names, trademarks, service marks, and similar terms, even if they are not identified as such, is not to be taken as an expression of opinion as to whether or not they are subject to proprietary rights. Printed on acid-free paper Springer is part of Springer Science+Business Media (www.springer.com)
Preface Different people have different attitudes toward Mathematica. Some very gifted people find its step-by-step pace to be an impediment to scientific thought. If you are one of those talented people, this book is not for you. It is written by a person who understands theory only when it leads to calculation, with every logical step under full public scrutiny. That is what Mathematica excels at. But Mathematica also permits a playful attitude toward theory, making possible little experiments and explorations that are usually left in a scientist's private notebook. These curiosity-driven excursions are an essential part of the creative process, which perhaps now, with Mathematica and with private websites, and in books like this one, can become a part of the public record of science. This book was originally intended as a concise compendium of group theoretic data and algorithms. The concise statements are indeed there, in the two Mathematica packages that are loaded at the top of every chapter. A true theoretician, versed in the Mathematica language, would need nothing else. But humans are not computers, and the development and exposition of the package materials takes time and space, and one thing led to another. I have tried to break the materials into lectures of fifty minutes length (if multiple examples are omitted). I remember with great loss those from whom I learned group theory. First, Prof. Andreas C. Albrecht taught it to his spectroscopic research students at Cornell. Afterwards, I was a post-doc with Prof. Cristopher Longuett-Higgins, Cambridge University, who pioneered the use of permutation groups in flexible molecule spectroscopy. And especially I remember Prof. Leo Falicov, Physics Department, University of California, Berkeley, who helped me with my first by-hand application of projection operators many years ago. And of course, this book owes its very existence to the monumental achievement of Stephen Wolfram in creating and developing Mathematica over the last twenty years. He created a genuinely “ new kind of science”, even before applying Mathematica to complexity theory. The Wolfram customer support group was helpful on many occasions; I would especially like to thank developers Adam Strzebonski, Andre Kuzniarek, and Buddie Richie, who pulled me out of several deep holes. I am grateful to several colleagues for help with mathematics and chemical theory: Prof. Kay Magaard, Math Department, Wayne State; H. Bernard Schlegel and Vladimir Chernyak, Chemistry Department, Wayne State; and Robert A. Harris, Chemistry Department, University of California, Berkeley. v
Symmetry Theory
I thank Tom von Foerster, formerly of Springer Verlag, for agreeing to this wild new way of publishing a book directly from Mathematica notebooks. The style sheet vonFoerster is named after him. Many special thanks to Jeanine Burke for making Tom's agreement come true, in spite of vicissitudes too numerous to mention. My wife, Carol Bluestone McClain, was my enabler through years of computer addiction. She is now helping me to dry out in the February summer of South America. I thank the students of Chem 8490, Winter 2007, Wayne State University, who helped with such intellegent attention, suggestions, and corrections: Michael Cato, Armando Estillore, Hao Li, Dr. Barbara Munk, Brian Psciuk, Sushant Sahu, Fadel Shalhout, Jason Sonk, Dr. Jason Sonnenberg, Huali Wang, and Jia Zhou. The book consists of all the materials that could be presented to this class in one semester. Wm. Martin McClain Professor, Chemistry, Wayne State University, Detroit, Michigan wmm@chem.wayne.edu Mendoza, Argentina, Feb. 18, 2009
vi
Contents 1. Introduction ........................................................................................1 1.1 What is symmetry theory? ................................................. 1 1.2 Outline of the book ..................................................................1 1.3 This is an interactive book ......................................................3 1.4 Learning Mathematica ............................................................4 1.5 The human's view of Mathematica ........................................5 1.6 Does Mathematica make errors ? ..........................................6 2. A tutorial on notebooks ....................................................................7 2.1 What are Mathematica notebooks? .......................................7 2.2 A basic notebook tutorial .........................................................8 3. A basic Mathematica tutorial ........................................................13 Section 3.1 This tutorial ...............................................................13 Section 3.2 On-line help ..............................................................14 Section 3.3 Basic operations .......................................................15 Section 3.4 The FrontEnd .................................... ....................... 19 Section 3.5 The Kernel ................................................................21 Section 3.6 Mathematica graphics .............................................24 4. The meaning of symmetry .............................................................29 4.1 Symmetry and its undefined terms ......................................29 4.2 Geometric symmetry .............................................................30 4.3 Algebraic symmetry ...............................................................46 4.4 Summary and preview ...........................................................54 5. Axioms of group theory ..................................................................55 5.1 Undefined terms in the axioms ............................................55 5.2 The four axioms .....................................................................56 ....................................... 56 5.2. The four axioms vii
Symmetry Theory
6. Several kinds of groups ..................................................................59 6.1 Numbers under Times ...........................................................59 6.2 Matrices under Dot ................................................................60 6.3 Axial rotation groups .............................................................62 6.4 Permutations under Permute .................................................63 6.5 Fruit flies under reproduction (a non-group).......................67 7. The fundamental theorem .............................................................73 7.1 Statement and commentary ...................................................73 7.2 Proof of the fundamental theorem .......................................74 7.3 How this theorem helps ..........................................................79 8. The multiplication table ..................................................................81 8.1 The generalized ‘‘multiplication’’ table ........................... 81 8.2 Latin square theorem .............................................................83 8.3 The Latin square converse ....................................................84 8.4 Automated multiplication tables ..........................................87 8.5 How MultiplicationTable works ..........................................90 8.6 Test MultiplicationTable ......................................95 8.7 Redundant groups ..................................................................96 9. Molecules ...........................................................................................99 9.1 Molecule definitions in Mathematica .................................99 9.2 Molecule "objects" ............................................................... 101 9.3 Molecule object operators ................................................... 102 9.4 How to make a molecule ..................................................... 103 9.5 Molecule graphics ................................................................ 104 9.6 StereoView ............................................................................ 109 9.7 AxialViews (a 3D shop drawing) ...................................... 110 10. The point groups .......................................................................... 113 10.1 Introduction ......................................................................... 113 10.2 The unit matrix ................................................................... 113 10.3 The inversion matrix .......................................................... 114 10.4 Roto-reflection matrices .................................................... 118 10.5 Only two kinds of matrices ............................................... 132 11. Euler rotation matrices .............................................................. 137 11.1 The Euler idea .................................................................... 137 11.2 The Euler rotations visualized .......................................... 138
viii
11.5 Euler headaches ......................................142
Contents
11.3 The Euler matrix theorem ................................................. 140 11.4 The function EulerMatrix[f, q,y] .................................... 141 11.5 Euler headaches .................................................................. 142 11.6 The inverse function EulerAngles[matrix] ..................... 143 12. Lie's axis-angle rotations ........................................................... 149 12.1 Introduction ......................................................................... 149 12.2 Rotation matrices in 2D form a Lie group ..................... 149 12.3 Lie group for 2D rotation .................................................. 150 12.4 Lie group for 3D rotation .................................................. 152 12.5 The operator AxialRotation[axis, angle] ........................ 157 13. Recognizing matrices .................................................................. 163 13.1 The problem, and a strategy ............................................. 163 13.2 Recognize a numerical rotation matrix ........................... 165 13.3 Recognize a rotoreflection matrix ................................... 168 13.4 Recognize a reflection matrix .......................................... 168 13.5 Operator RecognizeMatrix ............................................... 169 13.6 The complex eigenvectors ................................................ 170 14. Introduction to the character table ......................................... 173 14.1 Introduction ......................................................................... 173 14.2 The standard character table ............................................. 173 14.3 Some facts about the character table ............................... 175 14.4 The rightmost column; bases for reps ............................. 180 14.5 Various character table operators .................................... 181 15. The operator MakeGroup ......................................................... 183 15.1 An operator for constructing groups ............................... 183 15.2 MakeGroup, step by step ................................................ 184 15.3 MakeGroup with roundoff ................................................ 189 16. Product groups ............................................................................. 195 16.1 An introductory example (group C3 h) ..........................195 16.2 The product group theorem .............................................. 196 16.3 How to recognize product groups .................................... 197 16.4 Products with Ch vs. products with Ci ............................ 198 16.5 Some careful checking, and a scandal ..........................200 17. Naming the point groups ........................................................... 207 17.1 Molecules and point groups .............................................. 207 17.2 Schönflies names ............................................................... 207 ix
18.
Symmetry Theory
17.3 International names ............................................................ 209 17.4 Schönflies-International correspondences ...................... 212 17.5 Some interesting name correspondences ........................ 213 18. Tabulated representations of groups ...................................... 217 18.1 Cartesian representation tables ......................................... 217 18.2 Very simple groups ............................................................ 221 18.3 Groups with a principal axis ............................................. 223 18.4 Platonic groups ................................................................... 231 19. Visualizing groups ....................................................................... 251 19.1 Constellations vs. stereograms ......................................... 251 19.2 Constellations with a principal axis ................................. 253 19.3 Constellations based on Platonic solids .......................... 257 19.4 That's it, folks. What Next? .............................................. 267 20. Subgroups ...................................................................................... 269 20.1 Definition of subgroup ...................................................... 269 20.2 A simple but nontrivial example (group C3 h ) .............. 270 20.3 Finding all the subgroups of a group ........................... 272 20.4 An orientation issue ........................................................... 273 20.5 Symmetry breaking in PCl5 (group D3 h) ........................ 274 20.6 Definition of ‘‘symmetry breaking’’ ............................... 279 21. Lagrange's Theorem ................................................................... 283 21.1 Purpose ................................................................................ 283 21.2 Definition of coset ............................................................. 283 21.3 An operator for cosets ....................................................... 284 21.4 The coset lemma ................................................................ 286 21.5 Lagrange's theorem proved ............................................... 288 22. Classes ............................................................................................ 291 22.1 Qualitative meaning of classes ......................................... 291 22.2 Graphics of two "similar" elements ................................. 291 22.3 Finding all the similar elements ....................................... 293 22.4 Definition of class .............................................................. 294 22.5 A very pregnant little discussion ..................................... 294 22.6 Operator MakeClass .................................................... 295 22.7 Table lookup operators for classes .................................. 296 22.8 Theorems about classes ..................................................... 297 22.9 Class character, and other class properties ..................... 298 x
Contents
22.10 The Classify operator ...................................................... 300 22.11 Isomorphisms among order 6 point groups .................. 301 23. Symmetry and quantum mechanics ........................................ 309 23.1 Transformation of eigenfunctions ................................... 309 23.2 Delocalized orbitals of benzene ....................................... 313 23.3 Linear combinations of degenerate orbitals ................... 314 23.4 Qualitative meaning of degeneracy ................................. 319 23.5 Accidental degeneracy ...................................................... 320 23.6 Dynamic symmetry ............................................................ 321 23.7 Motion reversal symmetry ................................................ 322 24. Transformation of functions ..................................................... 329 24.1 What is a function transform ? ......................................... 329 24.2 An intuitive way (but it's wrong) ..................................330 24.3 The right way ...................................................................... 330 25. Matrix representations of groups ............................................ 335 25.1 Representation theory ........................................................ 335 25.2 Definition of representation .............................................. 335 25.3 Faithful and unfaithful reps .............................................. 336 25.4 MorphTest ........................................................................... 337 25.5 Why representations are important .................................. 338 25.6 The rep construction recipe .............................................. 339 26. Similar representations .............................................................. 343 26.1 Given two reps, are they similar? .................................... 343 26.2 Universal pseudocommuter matrices .............................. 344 26.3 Universal true commuter matrices ................................... 351 26.4 A whiff of Schur's Second Lemma .................................. 352 27. The MakeRep operators ............................................................ 357 27.1 Four MakeRep operators ................................................ 357 27.2 Polynomial basis (polynomials in x, y, z) ...................... 358 27.3 Matrix basis (Ix, Iy, Iz) ................................................ 362 27.4 Atomic orbital basis ............................................................ 362 27.5 Molecular orbital basis ...................................................... 363 27.6 Check the characters of the reps ...................................... 363 28. Reducible representations ......................................................... 371 28.1 The Cartesian representations .......................................... 371 28.2 Block diagonal multiplication .......................................... 372 xi
29.2 The MakeUnitary theorem ..................401
Symmetry Theory
28.3 Reducible and irreducible representations ..................... 374 28.4 Mulliken names of irreducible representations .............. 375 28.5 Example: the rep of the benzene orbitals ........................ 376 28.6 Reduction demo ................................................................. 377 28.7 What is the point of rep reduction? ................................. 378 29. The MakeUnitary operator ....................................................... 385 29.1 Unitary and non-unitary reps ............................................ 385 29.2 The MakeUnitary theorem ................................................ 390 29.3 The operator MakeUnitary ............................................... 394 30. Schur's reduction ......................................................................... 397 30.1 Schur's idea ......................................................................... 397 30.2 Two experimental rep reductions .................................... 398 30.3 The ReduceRep operator ............................................. 404 30.4 Tests of ReduceRep ...................................................... 405 30.5 What have we learned? ..................................................... 407 31. Schur's First Lemma .................................................................. 411 31.1 Statement of the Lemma ................................................... 411 31.2 Proof .................................................................................... 411 32. Schur's Second Lemma .............................................................. 415 32.1 Introduction ......................................................................... 415 32.2 Statement and discussion .................................................. 415 32.3 Proof, using the unitary property ..................................... 416 32.4 A whiff of the great orthogonality ................................... 418 33. The Great Orthogonality ........................................................... 421 33.1 Skewers ............................................................................... 421 33.2 Two statements of the Great Orthogonality ................... 422 33.3 Two Great Orthogonality demos ..................................... 424 33.4 Proof of the Great Orthogonality ...................................... 427 34. Character orthogonalities .......................................................... 431 34.1 Introduction and demonstrations ..................................... 431 34.2 Row orthogonality proof ................................................... 434 34.3 Column orthogonality proof ............................................. 436 34.4 Character tables are square ............................................... 438 34.5 Check the twiddle matrix numerically...........................439 34.6 Unique rows and columns ................................................ 440 34.7 A theorem of your very own ............................................ 440 xii
.............................................
Contents
35. Reducible rep analysis ................................................................ 443 35.1 The point of rep analysis ................................................... 443 35.2 Symbolic development of Analyze ............................ 444 35.3 Numerical example of rep analysis ................................. 446 35.4 The Analyze operator ................................................. 447 36. The regular representation ....................................................... 449 36.1 What is the regular representation? ................................. 449 36.2 Characters of the regular representation ......................... 452 36.3 The golden property .......................................................... 452 36.4 Demo of the golden property ........................................... 453 36.5 The d2 corollary ................................................................ 454 37. Projection operators ................................................................... 459 37.1 Projection operators in geometry ..................................... 459 37.2 Projection operators in algebra ........................................ 460 37.3 Symbolic derivation of the projectors ............................. 464 37.4 Your own examples of ProjectET ................................... 469 37.5 Your own examples of ProjectED ................................... 470 38. Tabulated bases for representations ....................................... 473 38.1 Introduction ......................................................................... 473 38.2 Basis sets from harmonic functions ................................. 473 38.3 Example: basis functions for D6 d ................................... 476 39. Quantum matrix elements ......................................................... 483 39.1 Matrix elements defined ................................................... 483 39.2 The Bedrock Theorem, and its corollary ........................ 484 39.3 Example using two polynomials ...................................... 486 39.4 Major example: benzene transition moments .................... 492 39.5 Proof of the Bedrock Theorem ......................................... 495 39.6 Integrals over functions of pure symmetry ..................... 497 40. Constructing SALCs .................................................................... 507 40.1 What are SALCs ? ............................................................. 507 40.2 Make SALCs, step by step ............................................... 508 40.3 Automation ......................................................................... 514 41. Hybrid orbitals ............................................................................. 521 41.1 Hybrid orbitals in general ................................................. 521 41.2 Pauling's hybridization strategy ....................................... 522 41.3 Implement Pauling's strategy ........................................... 524 xiii
43. Multiple symmetries ..............................................557
Symmetry Theory
41.4 The SALC shortcut ............................................................ 529 41.5 Electron density in sp3 orbitals ....................................... 532 42. Vibration analysis ........................................................................ 535 42.1 Problem and strategy ......................................................... 535 42.2 A step-by-step example ..................................................... 536 42.3 Automate the displacement rep ........................................ 541 42.4 Analyze the vibrations ....................................................... 543 42.5 One-click examples ........................................................... 546 43. Multiple symmetries ................................................................... 549 43.1 Inspiration ........................................................................... 549 43.2 Reps made from products of basis functions ................. 549 43.3 Lemma: Character of a direct product ............................ 551 43.4 Vibronic examples ............................................................. 551 44. One-photon selection rules ........................................................ 565 44.1 The main idea ..................................................................... 565 44.2 Polarization vectors and light amplitude ........................ 565 44.3 Projection of the one-photon operator ............................ 568 44.4 Transition oscillations ....................................................... 570 45. Two-photon tensor projections ................................................ 577 45.1 The operator for two-photon processes .......................... 577 45.2 Operators for tensor projection ........................................ 580 45.3 Self-purifying tensor elements ......................................... 582 45.4 Operators for tensor projection ........................................ 583 45.5 Two-photon tensor projection table ................................ 591 45.6 Axis permutation forbiddenness ...................................... 598 45.7 Alternative forms of the tensors ....................................... 599 46. Three-photon tensor projections ............................................. 601 46.1 The operator for three-photon processes ........................ 601 46.2 The projection ..................................................................... 603 46.3 Self-purifying tensor elements ......................................... 604 46.4 Operators for tensor projection ........................................ 604 46.5 Three-photon tensor projection table .............................. 611 46.6 Axis permutation forbiddenness ...................................... 640
xiv
48.5
Use the master equation .....................670
Contents
47. Class sums and their products .................................................. 643 47.1 Motivation ........................................................................... 643 47.2 Declaration of a "group algebra" ..................................... 643 47.3 Class sums ........................................................................... 644 47.4 ClassSum theorems ............................................................ 645 47.5 Class sum multiplication for a familiar group ............... 647 47.6 The ClassSumProduct operator ........................................ 648 47.7 ClassSumMultiplicationTable .......................................... 650 48. Make a character table ............................................................... 653 48.1 Introduction ......................................................................... 653 48.2 Make the CSMT again ...................................................... 653 48.3 Class sum product coefficients ........................................ 654 48.4 A strategy for the character table ..................................... 656 48.5 Use the master equation .. ................................................... 657 48.6 Use column orthogonality .. ............................................... 661 48.7 Final formatting .................................................................. 663 48.8 Character table of a new group ........................................ 665 A1. Mathematica packages .............................................................. 673 A2. SymbolizeExpressions ................................................... 675 A3. Matrix review .............................................................................. 677 B1. Bibliography ................................................................................. 679 B1.1 Wolfram Research, Inc. .................................................... 679 B1.2 Applied group theory books ............................................ 679 B1.3 Mathematica books ........................................................... 680 B1.4 Chemistry and Physics books .......................................... 681 B1.5 Math books ......................................................................... 682 B1.6 Data collections ................................................................. 682 B1.7 Research papers ................................................................. 682 Index ...................................................................................................... 685
xv
1. Introduction 1.1 What is symmetry theory? In this book, Symmetry Theory means group theory, as applied to groups of symmetry transformations. The deepest roots of mathematical group theory deal with algebra problems and permutation problems, but students of chemistry and physics usually encounter it first in the context of geometrical symmetry problems in crystals and molecules. All students of physical chemistry and molecular physics must learn a little group theory, if only to avoid utter mystification by phrases like “the B2 u states of a D6 h molecule” or “the diamond crystal belongs to m3m”. There are now many undergraduate physical chemistry textbooks that treat group theory in a single chapter, but in order to do so they must leave out all the logic, presenting only lists of things to be memorized. You should read such a chapter, if you have never seen one. It will take you quickly over the most common uses of group theory in molecular physics, but if you are at all resistant to the memorization of authority, it will leave you hungry for more. And of course, on the basis of such a chapter, you would never be able to think of anything new on your own. In this book, nothing will be presented from authority; the logic will be foremost, and you will be preparing your mind to carry symmetry theory forward into new areas.
1.2 Outline of the book
Part I Point groups and their construction Chapter 2 and Chapter 3 introduce you to Mathematica, an electronic logic engine that automates routine calculations, symbolic as well as numeric. Chapter 4 through Chapter 8 develop the basic relationship between symmetry and mathematical group theory. Chapter 9 introduces the Mathematica molecule, and its automated graphics.
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_1, © Springer Science+Business Media, LLC 2009
1
Symmetry Theory
Chapter 10 through Chapter 13 develop some matrix operators necessary for constructing symmetry transformation matrices, and for recognizing such matrices when they appear as a construction. Chapter 14 introduces the character table, and the concepts of Class and Species. Nothing is derived or proved here, but the questions that will occupy the next several chapters are explicitly laid out. Chapter 15 through Chapter 19 show how molecular point groups are made, organized, named and visualized. Part II Representation Theory Chapter 20 through Chapter 22 describe subgroups and classes Chapter 23 explains how group theory relates to quantum mechanics, and why the names that appear in the character table are used as the names of spectroscopic states. Chapter 24 through Chapter 28 introduce representations based on symmetric objects in the most general sense, and the idea of reducible and irreducible representations. Chapter 29 through Chapter 33 present the basic theorems of abstract group theory, culminating in the Great Orthogonality Theorem. Schur's Lemmas for the Great Orthogonality are introduced in a quasi-experimental way that may imitate the way that Schur discovered them. This brings the topic to life again, presenting questions first and answers second. In Chapter 34 to Chapter 36 we draw out some consequences of the Great Orthogonality which clear up the final mysteries about the point groups . The character orthogonalities underlie the properties that all character tables have in common, and are of great practical consequence. They permit the automatic reduction of any reducible representation, and permit the automated construction of all possible irreducible representations for any given group. Chapter 37 presents the concept of projection operators, which can take a mathematical object of no symmetry whatsoever and divide it systematically into parts that have simple symmetries. These operators have long been known theoretically, but their application without automated mathematical help is tedious and uncertain. Now, for the first time, the operators and tabulations in this book make them easy to use. It is quite fair to say that this book was written to make this chapter possible.
2
Outline
Part III Applications, and automated construction of character tables Chapter 38 to Chapter 46 deal with applications of group theory in chemistry. We make extensive use of all the automated operators developed in Parts I and II. Suddenly the fog lifts, and you see how true it is that if you know the structure of group theory, the applications of it in molecular theory follow a unified theme, and are easy and transparent. In Chapter 47 and Chapter 48 you learn that if you have the multiplication table that describes a group, you can apply machinery that will turn it into the character table for that group. This is a little advanced, but it is potentially of one of the most useful algorithms in the book. New permutation groups appear all the time in the spectroscopy of flexible molecules, and their character tables are quite urgently needed. Appendices and Bibliography The book ends with three appendices and a bibliography. The appendices deal with calculational or mathematical issues that arise in the book, but which do not lie on the main path. They may be read only by interactive readers.
1.3 This is an interactive book If you are reading this on paper, you may not know very much yet about Mathematica. It is a computer program that carries out the details of algebra, calculus, and numerical computation. It is changing the way that scientists learn and use mathematics, because it frees the mind to concentrate on the issues of logical strategy, rather than on details of symbol manipulation. Its speed and unerring accuracy gives one the energy and confidence to forge ahead with new and unexpected results, raising the creative process to new levels. There is a paper version of this book and a CD (compact disk) version. The paper version is a reference work, providing most of the material on the CD. But you can put the CD into a computer and read the unabridged version from the screen, letting Mathematica recalculate all the results in the book as you go. If you do this, the Mathematica program will always be prepared to carry out experiments that are suggested in the text, or (even better) that you may think of on your own. This interactive mode may make this book one of the first that people will prefer to study from a computer rather than from paper. (Of course, for quick reference purposes, nothing beats reaching for a book on a shelf. That is why there is a hard copy.) Your computer must be able to run Mathematica before you can use the book interactively. Mathematica is now widely available through institutional site3 licenses that are very convenient to use, or as stand-alone copies. The student price is less than the author once paid for a slide rule made of bamboo and ivory.
Symmetry Theory
Your computer must be able to run Mathematica before you can use the book interactively. Mathematica is now widely available through institutional site licenses that are very convenient to use, or as stand-alone copies. The student price is less than the author once paid for a slide rule made of bamboo and ivory. If you work with this book interactively, you will learn Mathematica and symmetry theory together, but it is the logic of symmetry theory, not the logic of Mathematica, that drives the book. We introduce Mathematica operators only when we need them for symmetry theory, so a useful application is always at hand for any programming skills you learn. When you finish, your knowledge of symmetry theory will be quite solid, as far as this book takes you. You will feel that it is easy and natural to carry out certain group theoretic calculations which in the past were always tedious and prone to human error, the domain only of specialists. The interactive mode of this book lets you learn group theory in a way that partly imitates the way it was discovered by research mathematicians. The book provides axioms, definitions, and leading questions. The questions are then explored before definitive answers are given, and you are encouraged to use Mathematica yourself to do numerical experiments; to see if you can arrive at solutions before they are presented. Thus this book teaches the general analytical skills required for all research, as well as teaching Mathematica and symmetry theory.
1.4 Learning Mathematica People often say that Mathematica has a very steep learning curve, but in over five years of introducing undergraduates to Mathematica, the author has not found this to be true. After a few hour's instruction, as given in Chapter 2 and Chapter 3 of this book, along with model examples of particular problems, students can begin to operate with Mathematica. It is more accurate to say that Mathematica, like mathematics itself, has a very long learning curve. Stephen Wolfram, the chief architect of Mathematica, frequently says that he is always learning to be a better user of Mathematica. The program was designed to grow, and in more than a decade of development by a large staff of professionals, it has become a vast but strictly orderly program. It now encompasses much of the knowledge contained in the mathematical tables and handbooks that line the reference shelves of university libraries, and in a form much easier to use. The only way to learn Mathematica is to use it. After you run through the basic tutorials of Chapter 2 and Chapter 3 and work with the examples in the first few sections of the book, you will be begin to be able to use Mathematica on your own. If you finish the book, you will have learned enough tricks to make you a 4quite competent user of Mathematica. Also, you will have learned how to use Mathematica's own on-line documentation to teach yourself any new area you might need, and you will feel that you can use Mathematica to tackle problems that arise in your own research.
The only way to learn Mathematica is to use it. After you run through the basic Learning Mathematica
own. If you finish the book, you will have learned enough tricks to make you a quite competent user of Mathematica. Also, you will have learned how to use Mathematica's own on-line documentation to teach yourself any new area you might need, and you will feel that you can use Mathematica to tackle problems that arise in your own research. The primary printed reference on Mathematica is Stephen Wolfram's The Mathematica Book. It describes Mathematica up to the introduction of Version 6. The new Version 6 operators are missing, but very little in it is obsolete. Currently the primary reference is the online Documentation Center, accessible as the first item in the Help menu of Mathematica itself. It provides a document for every operator, as well as many concise tutorials on specific areas. It sets a new gold standard for computer program documentation. Click here for a very selective list of Mathematica books, all more tutorial than Wolfram's book, but all less complete.
1.5 The human's view of Mathematica There is a version of Mathematica for every major kind of computer. From a human's point of view they all work the same way, and they all produce the same kind of Text files, called notebooks. Humans can exchange notebooks electronically without concern about differences among computers. When a person first begins to use a computer, it is difficult to get used to the machine's combination of brilliance and stupidity. The simplest, most obvious variations you make in syntax are just not understood (like using the letter x to indicate multiplication). The iron discipline of sticking to a precise syntax is for beginners the hardest thing to learn. But this is true of all computers programs, not just Mathematica . When you first launch Mathematica, only the “front end” is activated. A notebook will appear, either blank or with material in it, depending on how you launch. With the front end alone, you may read the notebook and edit its prose. But you cannot calculate until you start the Mathematica “kernel”. The kernel starts up automatically the first time you ask it to evaluate something. (Therefore, the first answer may be slow to come up.) Mathematica provides typeset mathematical notation. This includes Greek and other alphabets, specialized mathematical characters, and standard mathematical two-dimensional notation for integrals, powers, and fractions, as well as matrices and vectors, and other objects. Here, for instance, is a nicely typeset Mathematica input-output pair :
5
Symmetry Theory
p à x sinHxL â x
-
1 2
x p Ix2 M
-p
HGHp + 1, ä xL H-ä xL p + Hä xL p GHp + 1, -ä xLL
It might take you some time to find that in a table of integrals. But Mathematica did not look it up in a table; it uses a general symbolic algorithm, unlike anything normally taught to humans, and it handles variants as easily as simple cases : p à x sinHa x + bL â x
-
1 2a
x p Ia2 x2 M
-p
HGHp + 1, ä a xL HcosHbL - ä sinHbLL H-ä a xL p +
Hä a xL p GHp + 1, -ä a xL HcosHbL + ä sinHbLLL
That might not be in any table, even the largest. You could of course deduce it from the result above, but it would take some time, and you could easily make mistakes in the process. Welcome to the world of computer-assisted mathematics!
1.6 Does Mathematica make errors ? There is no way to make an absolute guarantee against error in a computer program. Confidence that a program is error-free comes from years of testing under all kinds of unforeseen circumstances. The public use of a program puts it through more unforeseeable twists and turns than any testing program ever could. The parts of Mathematica we will use in this book have withstood public use for over ten years, and we have great confidence that any errors in the basic central code have long since been found and corrected. Nevertheless, the wise user of Mathematica sets up frequent checks for selfconsistency. This is one of the things we will teach as we go. We have never found a Mathematica error with these checks, but we have found plenty of human errors. Consistency checking is the way that rigorous minded scientists deal with all the black boxes they must use in this electronic age.
6
2. A tutorial on notebooks If you want to read this book “live” (as intended) you will need to read this chapter on screen and with Mathematica running, and do the things it says to do. You won't get much out of it by just reading the hard copy, but here it is for quick reference :
2.1. What are Mathematica notebooks? Every document produced by the Mathematica front end is a “notebook”, and every chapter of the CD version of this book is a “notebook”. The notebook allows a document to present itself in outline form, with each topic and subtopic opening up for reading on command, or closing up again on command. Notebooks require a little explanation, but they soon seem very natural. Notebooks are divided into cells, which are rather like paragraphs. The individual cells are usually grouped by enclosing brackets of increasing length. When you read this book on-screen, you will see nested blue brackets on the right side of the screen. In the printed book, this chapter is the only one that displays the nested brackets. Look This paragraph-like cell is grouped by a secondary Section bracket that encloses all of Section 2.1. All Section brackets are in turn enclosed by an outer bracket that begins at the top of the notebook and runs all the way to the bottom, enclosing all of Chapter 2. If you click once on the outer bracket, it will turn dark and you will have “selected” the whole notebook, as if for Copying or (God forbid!) Deleting. Well, of course, you can delete the loaded copy from RAM, but not from the CD. If you click twice on the outermost bracket, the notebook will fold up and you will be left with only the Chapter title showing. To reopen, click twice on the outer folded bracket (with a small dark triangle, like a downpointing half arrow), and the notebook will reappear. Go ahead. Do it. The whole reason for putting this book on a computer is to let you try things as we go. To open the Section heading below (“2.2. A basic notebook tutorial”), click twice on the middle bracket to its right, the one with the little dark triangle at the bottom It will unfold, showing the subsection headers. W.M. Symmetry Theory in Molecular Physics with Mathematica, They McClain, open similarly. DOI 10.1007/b13137_2, © Springer Science+Business Media, LLC 2009
7
Symmetry Theory
triangle at the bottom It will unfold, showing the subsection headers. They open similarly. To fold it up again, click twice on the same (but now expanded) bracket. It will shrink and the little dark triangle (or downward half-arrow) will reappear, indicating that the bracket is expandable. All multiply bracketed cells can be unfolded and folded up again in this way.
2.2. A basic notebook tutorial 2.2.1. Magnification Every notebook window has a magnification option on its bottom edge, just left of the horizontal scroll bar. By default, the chapters of this book are set for 200%. Click the little dark triangle and other magnification choices will drop down. Try some other sizes.
2.2.2. Make a new cell with 1+1 in it Move the cursor around until, between two existing cells, it turns to a horizontal bar with split ends. Click once, and it turns to a long horizontal “insertion line”. This is where the new cell will appear, if you start typing. For instance, you can do it just below, typing “1+1” (without the quotes) : The “1+1” you just typed is in an Input cell, distinguished its Bold Courier type face. This is the kind of cell you want when preparing input for calculations. (Go ahead, do it! Nothing terrible can happen!) Now we discuss how to get Mathematica to compute 1+1 for you.
2.2.3 The initial computation Put your cursor anywhere in the Input cell you just created, and hit ÷-ó or ÷-ç. One of these should cause something to happen; remember which one does the job. We will call it the Process command.
8
Notebook tutorial
In this book, the Process command will be represented by ¿ .
On a Macintosh, you may use ó by itself, or the ÷-ó combination, or the ÷-ç combination. On PCs, the ÷ is required. If you are starting up a new notebook, you may now experience a little distraction. A question will appear in a box :
Do you want to evaluate all the initialization cells in this notebook? For notebooks from this book, you must always click YES. Otherwise, the notebook may not work properly.
In this book, the initialization cells are mostly in the Preliminaries section at the top of every chapter. (You can open them and see them, but they are hard to understand; don't try until you know more.) After the question disappears, an Output cell appears, bracketed with its Input cell. These cell types can be distinguished at a glance: Input cells have Bold Courier typeface; Output cells have Plain Courier typeface. After processing, notice the appearance of the blue In[ ] and Out[ ] cell labels. These will prove very useful. Unprocessed Input cells (a major cause of error for beginners) will not have the blue label. Try a few other simple sums until you are very familiar with the Pro cess command. On a Macintosh note that both ó and ÷-ó can act as a Process command. Then clean up after yourself. Select the innermost bracket of each new cell and hit the delete key. Or, leave one example standing. It's up to you.
2.2.4 Text cells Notebooks have Text cells as well as Input and Output cells. Text cells provide a place for commentary on your calculation (or for most of the text of this book). This cell is a Text cell. All Text cells have a short horizontal line near the top of the innermost cell bracket. To make a new Text cell, make an insertion line and start typing. A new cell will appear, and it will be, by default, an Input cell. After a few characters, stop and issue Option-Command-7 (that's õ-á-7, or õ-í-7). The cell will turn to a Text cell, distinguished by its 10-point Times type face.
9
Symmetry Theory
To make a new Text cell, make an insertion line and start typing. A new cell will appear, and it will be, by default, an Input cell. After a few characters, stop and issue Option-Command-7 (that's õ-á-7, or õ-í-7). The cell will turn to a Text cell, distinguished by its 10-point Times type face.
2.2.5 Heading cells Notebooks also have heading cells of several different types. Make an insertion line and start typing a heading. After a few characters stop and issue Option-Command-4 (õ-á-4, or õ-í-4). It will become a cell of type Section, in 14 point type. Other headings are made by commands of the form Option-Com mand-digit (õ-á-digit or õ-í-digit), where digit is any digit from 1 to 7 . In the vonFoerster style sheet used by this book, digits 1-6 are headings of decreasing rank, and 7 is Text, 8 is a magnification toggle, and 9 is Input. You may switch a cell freely among any of these types by putting the cursor anywhere inside it, holding down Option-Command ( õ-á, or õ-í ), and typing different digits. Try it.
In this book every chapter uses the hierarchy ChapterLine (autonumbered, õ-í-1) Section (autonumbered, õ-í-4) Subsection (autonumbered, õ-í-5) Subsubsection (not numbered, õ-í-6)
2.2.6 Processing cell groups Select any grouping bracket, open or not, and issue a Process command. This will processing all the selected cells. If you select the outermost bracket that encloses the whole notebook, you will Process the whole notebook with one hit.
10
Notebook tutorial
2.2.7 The active way to read a notebook With the cursor right here in this cell, do a ÷-ó . The 1+1 below will be selected and another ÷-ó sends it to the processor. A third selects the next evaluatable cell, and a fourth evaluates that. Try it : 1+1 2+2 You can click down the whole notebook by keeping the Shift key depressed and repeatedly typing Enter. This is a good way to evaluate a pre-written notebook at a human pace, following the logic as you click down. You can stop at any point and carry out experiments of your own. If you want to do further work in a newly opened notebook, select everything above your starting point and ¿. It will run down to your starting point, making all necessary the definitions as it goes. Then you can start work.
2.2.8 Fold and unfold groups of cells Select a grouping bracket and do a ÷-í-} (shift-command-closeBracket). The selected bracket (and all sub-brackets within it) will close. If you select the whole notebook, you can close the whole notebook with one stroke, leaving only the title showing. Then click twice on the outermost bracket, and you get a nice compact index of Sections for the whole notebook. Similarly, ÷-í-{ (shift-command-openBracket) opens a selected section, and all its subsections. This is really all you need to know to get started using notebooks.
11
3. A basic Mathematica tutorial If you want to read this book “live” (as intended) you will need to read this chapter on screen and with Mathematica running, and do the things it says to do. You won't get much out of it by just reading the hard copy, but here it is for quick reference :
Preliminaries
Section 3.1 This tutorial This tutorial is for Version 6 of Mathematica. It is a framework for running quickly over the basic terms and concepts. It is probably a good way to get started, but you will not really learn these things except by practice, bringing them up in your consciousness from your own memory. Like riding a bicycle, it becomes very automatic, but only with practice. If you have not yet read Chapter 2, the NotebooksTutorial, it will help a lot if you do so now. In this tutorial, nothing on a colored background will evaluate or copy. You should retype it in a cell of your own between the colored cells, and then ¿ . Typing forces you to notice important details that escape you if you merely read. Type in everything exactly as shown (particularly punctuation, and upper and lower cases). After you see the given example work correctly, make variations of your own. As you work the examples, pass nothing over with a shrug; let nothing mystify you; everything that happens, happens on your orders. If you see something strange, examine your last input for typos before anything else. A small accidental space in the middle of a variable name, or some other trivial typo, can make all the difference. Explanations, when needed, follow the examples.
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_3, © Springer Science+Business Media, LLC 2009
13
Symmetry Theory
Section 3.2 On-line help 3.2.1 Quick, basic help: the question mark No one can remember all the details of all the Mathematica operators, so there is an excellent on-line help facility. Just prepend a question mark to the name of the operator : ?Solve ¿ You will see the syntax of Solve, and a basic description of its action. Here is an example : Solve[x-2y0,x] The output is a little surprising, but you will learn to read it. For humans, the little arrow “®” basically means “=” . For the computer it has a meaning you will learn below. Sometimes the exact name is what you have forgotten. Type ? and then some part of the name that you remember, surrounded by wildcard asterisks: ?*Plot* This brings up every operator that contains Plot anywhere in its name. Click on the one you want, and help will appear. For a good relevant example, click on Plot itself and try to read what comes up.
3.2.2 More detailed help No computer program has more detailed help than Mathematica. Click on the >> symbol at the end of the thumbnail sketch above, and a whole notebook devoted to the Plot operator will appear. Do it. The notebook is too long to make it a part of this document, so when you have finished looking at it, just click it closed and come back here.
14
On-line help
3.2.3 The Documentation Center The first item under the Help menu is the Documentation Center (DC). Click on it and you will see a clickable outline of everything in the DC. But the best way to use it is to type a term into the long thin box at the top, and ¿. Mathematica will search the DC for all occurrences of your term, and present you with a clickable list of DC destinations. It is very similar to a Google search.
Section 3.3 Basic operations 3.3.1 Simple arithmetic and algebra
(a) Add, subtract, multiply, and divide 2+3 ¿ 2-3 ¿ 6/3 ¿ 2*2 ¿
The * means multiply, as in most languages
2ø2 ¿ The ø also means multiply (only in Mathematica ) Make your own cell and try these things out. Click above or below this cell to get the insertion line, and then start typing the material from the boxed cell above. (b) Powers The old-fashioned (all-on-the-baseline) way to write a power is 2^3 ¿
The carat ^ means “to the power”. It is the uppercase 6 key.
Here is the way to get the power up off the baseline (where it belongs!) : 2â^ Makes a superscript template on the 2, like 2 . Fill it : 23 ¿ Come back to the baseline with âø .
15
Symmetry Theory
3.3.2 Three useful palettes
The BasicInput palette Follow the click chain PalettesMenu @ BasicMathinput. A palette will appear, containing templates for a number of mathematical notations.
Drag it to the side by its top bar. Make an insertion line and
click on a palette item. The item will appear in a new Input cell. Inside an existing cell, the new item will appear where ever you leave the blinking cursor.
The SpecialCharacters palette Follow the click chain PalettesMenu @ SpecialCharacters. You may click to insert any character that Mathematica has. Under Letters his there are five alphabet styles; under Symbols there are seven whole palettes of math symbols. Many of these were in the past available only to professional typesetters. Look at them all.
The AlgebraicManipulation palette Follow the click chain PalettesMenu @ AlgebraicManipulation.
In an input cell
containing a square of some fomula, select the formula and click on Expand. Then selectthe result and click on Factor. If you are in an Input cell, it will happen right in-place. If not, a new Input cell will open, containing the expression, as changed. Then try some of the other operations.
16
Basic operations
3.3.3 The most basic operators
Set (the " = " sign) The mathematical equal sign (=) is left-right symmetric for a very good reason: The expressions that stand on either side of it must evaluate to the same numerical value. But this is NOT how the " = " sign is used in computer languages. The earliest languages used it in commands like aMemoryLocation = aNumber This sent the given number into storage at the given location. This is not mathematical equality, but this usage cannot be stopped. So the name of "=" is Set. In Mathematica, memory locations are referred to by symbolic names, like q. Try q¿
If the location q is free, the symbol q will be returned. If not, see Clear (below).
q=7¿
Location q is Set to 7, and 7 is returned.
q¿
This time, the number 7 is returned.
Until the content of location q is changed, Mathematica will always automatically turn symbol q into 7. Thus 7 has become the "meaning" of q.
(e) Clear Clear[q]¿
This undoes the Set operation, freeing up the given
memory location.
17
Symmetry Theory
(f) Equal (the double "==" sign) Since the " = "
is already taken by Set, mathematical equality needs
another symbol. It is two equal signs typed together with no space : 1 == 1¿ 1 == 2¿ a == b¿
Mathematica returns an answer when it can, and repeats the
question when it can't. Unlike primitive numerical languages, Mathematica can put symbolic expressions into memory locations. You can give a name to an equation : eqName = 2 x == 3 y ¿ eqName¿
(e) Use a decimal or not? It matters. Sin[2.] ¿
Note the decimal point.
Sin[2] ¿
Note the absence of the decimal point
This requires explanation. The decimal point tells Mma that you are willing to accept machine accuracy; the absence of the decimal means you want an exact result. That is why it refuses to do anything with Sin[2], which is an irrational number that has no exact representation. (f) Symbols for irrational numbers
c=
2 ¿
c2 ¿
The
template is typed as â2 .
The c behaves as it should when squared.
(g) Rule and ReplaceAll Clear[x]
¿
Rules are similar to equalities, except that they have a right-pointing arrow “®” in them instead of an equal sign. We write a rule that we name as xRule . Use å - > å to make the nice little arrow. That's escape-minus-greaterthanescape):
18
Basic operations
xRule = x®2
¿
Rules would be useless without the ReplaceAll operator. It is written as a two-stroke combination /. between an expression and a Rule. It causes the Rule to be applied to the expression; in this case it causes every x in the expression to be replaced by 2. x2 . xRule ¿ You don't have to give names to Rules. You can just say x3 . x ® 3 ¿ The great thing about Rule and ReplaceAll is that it does nothing permanent to the symbol on the left side of the Rule (the x, in this case). Ask what Mathematica has now for the value of x : x
¿
Nothing! It is still an unset symbol, though we used it above as a temporary container for two different numerical values. This will be more useful than you can possibly imagine right now.
Section 3.4 The FrontEnd Mathematica consists of two executable programs, the FrontEnd and the Kernel. This section describes the FrontEnd; the next section describes the Kernel. The FrontEnd constructs all the displays on your screen and interprets all input from the keyboard and the mouse. The Kernel does all symbolic and numeric calculation. When you click twice on a notebook icon to open it, only the FrontEnd starts up. The Kernel starts automatically the first time you send anything to the processor. For instance, 1¿ will start the Kernel. It takes a perceptible time to start. The next time you open a new notebook, look for this.
19
Symmetry Theory
3.4.1 A few FrontEnd tricks Greek letters, and other strange characters Greek letters may be clicked from a palette, or may be input right from the keyboard. Greek letters, and other strange characters The FileMenu @ Palettes @ CompleteCharacters palette contains many specialized characters available in the past only to professional typesetters. It provides an alternative way to get Greek letters, among many others, by clicking. Check it out. There are keyboard shortcuts for everything on all palettes. The Greek letters are particularly easy; just type the Latin equivalent, surrounded by escapes : å
stands for the escape key, esc. Try
åaå
Greek alpha
åbå
Greek beta
åpå
If you want your pi in Greek, type this.
åphå
Φ Some need two strokes.
åpså
Ψ
åSå
S Capitals, too
Sin[åpiå / 3] ¿
Π has a preassigned meaning, the same as
“Pi”. Sin[åPiå / 3] ¿
but P is not Π.
Subscripts and superscripts We have already seen how to make a superscript template with â^ (control-carat) to raise an expression to a power. The subscript is quite similar, though there is a distinction to be made. But first, some painfully detailed instructions on how to type a subscript. Type a symbol, then type â- (control-minus). This produces a selected subscript template below and to the right of the symbol. Fill the template with something simple. Now come up to the main line with â-ø ( control20 ace). Now you have a subscripted object that acts for most purposes like a symbol. Later you will learn to Symbolize it when needed so that it becomes a true symbol.
FrontEnd
something simple. Now come up to the main line with â-ø ( controlspace). Now you have a subscripted object that acts for most purposes like a symbol. Later you will learn to Symbolize it when needed so that it becomes a true symbol. c1 = 2.0; 8c1 , c2 < You can use it as input to functions : 9Log@c1 D, c1 2 =
The high-low toggle (â5) Here is a handy trick. Suppose you want to write c1 squared. If you write the subscript first and then the superscript, it will look like c1 2 . The is not terrible, but sometimes you would rather have the superscript directly over the subscript. For this, write c1 , and then with the cursor blinking behind the sub-1, do a â5 ( control-5). This will create an insertion box directly above the subscript. Actually, you may also do it in the opposite order- the control-5 operation is a toggle between matching high and low insertion boxes. It also toggles between overscript and underscript boxes.
Section 3.5
The Kernel
3.5.1 Introduction The Kernel knows nothing about what the FrontEnd has on any line until you give that line an Enter or Shift-Return ( ¿ ). This is particularly true of a freshly opened notebook that has lots of In-Out pairs in it. The FrontEnd displays them, but the Kernel know nothing about them. The very commonest mistake in Mathematica is to forget this. Everybody does it; all you can do is learn to recognize the symptoms and scroll back up to run the lines that were skipped. If you want the Kernel to be aware of all the work that you did in an old notebook, you must rerun it FROM THE TOP. This is easy. Just select the outermost bracket for the whole notebook, and hit Enter or Shift-Return ( ¿ ). To do this at a more human pace, hold down Shift while repeatedly hitting Enter. This jumps you from one executable cell to the next (and then executes it), so you can follow what is going on, fix errors as they are encountered, etc. 21
Symmetry Theory
Enter. This jumps you from one executable cell to the next (and then executes it), so you can follow what is going on, fix errors as they are encountered, etc.
3.5.2 Five kinds of brackets 1. Square brackets [...] (Operators) The processor works only on square brackets. Indeed, square brackets must never be used for anything other than an Operator[operand] construction. In particular, they must never be used to group algebraic expressions. Many expressions contain nested square brackets. The processor looks for the innermost pair and processes it first. Then the expression is simply recycled back into the processor afresh, and again the innermost pair is located. When all the square brackets are gone, the fully evaluated expression is displayed. Ordinary functions are just operators that operate on numbers, so we can make a simple example of this by nesting several functions around a single number : First evaluate ArcTan[Log[Sin[1.23]]]. Then do them one at a time: Evaluate Sin[1.23], then paste the numerical value into the square brackets of Log[], and then the Log into the ArcTan, to verify the "innermost first" rule.
2. Parentheses ( ... )
(Algebraic grouping)
Parentheses are used exclusively for algebraic grouping: (u+v)/(f (b^2 + c^2)) This means you will have to give up your old favorite, f(x). In Mathematica, f(x) means “f times x” and never anything else. The function “f of x” must be written with square brackets as f[x], or as one of its aliases, like x//f. Do not ever try to group symbols using curly braces a{b+c} or square brackets a[b+c]. The processor understands these expressions in a quite different way. 2 Cos@ΦD Sin@ΦD ICos@ΦD2 -Sin@ΦD2 M After typing the above and looking at its output, copy it and paste it into TrigReduce[] to see what Mathematica knows about trig : 22
Five kinds of brackets
TrigReduceA2 Cos@ΦD Sin@ΦD ICos@ΦD2 - Sin@ΦD2 ME 3. Curly braces { ... } (Lists) Curly braces are used exclusively to enclose lists of things. The things listed are separated by commas. The list is the one and only data structure used by Mathematica. It is a theorem that any data structure is equivalent to a nested list structure, so there is no need for anything else. Below, note that abcd is a single symbol, whereas {a,b,c,d} is a list of four symbols. abcd = {a,b,c,d}; ABCD = {A,B,C,D}; Many clever algebraic operations can be carried out on lists. abcd . ABCD
(* the Dot product *)
abcd * ABCD
(* the Times product *)
Many functions have the Listable property. example :
The Log function is an
Log@81., 2., 3., 4.
81., 2., 3., 4.<
¿
Here is a nested list structure (a matrix), and the basic use for it with a vector : matrix = {{a,b},{c,d}}; vector = {e,f}; matrix.vector vector.matrix
23
Symmetry Theory
4. Comments (* … *)
(ignore)
Sometimes you want to put a short note beside some input, without going to the trouble of making a Text cell for it. This is done by enclosing your comment in the two-stroke combination (* as the opener, and another two-stroke combination *) as the closer. Everything inside will be ignored by the processor. FactorAa2 - b2 E
(*example of factoring*)
5. Double brackets P ...T
(Part)
Double square brackets, or double-struck square brackets, are the humanfriendly guise of the Part operator. In the list {a,b,c}, the “b” is Part 2. You bring it out on its own with {a,b,c}[[2]]
¿
The better-looking form below is typed as å[[å and as å]]å. {a,b,c}P 3T ¿ Many expression have parts that have parts. Here is an example of a List of Lists. {{a,b,c},{d,e,f}}P 2,3T ¿ Part 2 of the main expression is {d,e,f} . Part 3 of that is f.
Section 3.6 Mathematica graphics 3.6.1. Two dimensional graphics Two- dimensional graphics are made by the Graphics operator working on a graphic “primitive”, like Circle : circ = Graphics@Circle@D, ImageSize ® 72D
24
Mathematica graphics
The Head of the output is also called Graphics; thus, the output is said to be a “Graphics object”. Head@circD Graphics
There are only 13 Graphics primitives. Some of the most useful are Cir cle, Line, Arrow, Text, Rectangle, and Polygon. Look up Graph ics in the Doc Center and open MoreInfo to see a list of them all. Usually, the Graphics operator is applied to a List of primitives interspersed with various directives. First, make such a list: grList = 8PointSize@1 10D, Red, Point@80, 0
Read the grList carefully. The only primitive that appears is Point[x,y], which says to draw a point with center at x,y. Everything else is a directive. The list starts with the directive PointSize[1/10], which says that every following point is to have a diameter 1/10 the total width of the figure. The colors names are also directives, each establishing a color that will apply to all following primitives (until another color directive is given). Now feed grList to the Graphics operator, along with options to control the Plot Range, ImageSize and the Background color : bigDots = Graphics@grList, PlotRange ® 88-2, 12<, 8-1, 1<<, ImageSize ® 200, Background ® GrayLevel@0.6DD
The output is the graphic itself, a graphics object named bigDots. Look at the Head of bigDots. Then change their x,y coordinates and restructure the list to make interesting pattern of Red and Black dots with different sizes. Make a thick line located on the same background: 25
Symmetry Theory
Make a thick line located on the same background: thickLine = Graphics@ 8Thickness@0.02`D, Line@88-1, 0<, 811, 0<
Thickness[.02] directs all following lines to have a thickness 2% of the width of the figure. Graphics objects can be shown again, or combined, by the Show operator. lineInFront = Show@8bigDots, thickLine
dotsInFront = Show@8thickLine, bigDots
In the Show list, the first object is drawn first; then later objects overlay each other in list order.
3.6.2. Three dimensional graphics Three dimensional graphics work like two dimensional graphics, except that the operator is Graphics3D, and the primitives are specialized for three dimensions. For instance, Point now requires three coordinates, not two. Others, like Cuboid, Cylinder, and Sphere are intrinsically 3D only. Also, the directives Opacity, Specularity, EdgeForm, and FaceForm address issues that do not arise in 2D. We show a single example, making use of a handy operator Graphics Complex[ptList,grList]. The idea behind it is to specify all the 3D points up front in ptList, and then refer to these points in the grList simply as integers 1,2,… . For a diatomic, we need only two points:
26
Mathematica graphics
diatomicMolecule = GraphicsComplex@ H*ptList*L88-1, 0, 0<, 8+1, 0, 0<<, H*grLIST*L8 Brown, Cylinder@81, 2<, .1D, Red, Sphere@1, 0.5D, Blue, Sphere@2, 0.4D
Book readers will see nothing very remarkable about this. But interactive readers can use the mouse to drag this image around into any desired orientation: 8dM, dM, dM< :
,
,
>
This is one of the very best things about Mathematica's 3D graphics. If the structure is complicated you can maneuver it around until you understand it exactly. Biochemists have elaborate programs for doing this with macromolecule structures, but here it is just part of the core of Mathematica.
27
4. The meaning of symmetry Preliminaries
4.1. Symmetry and its undefined terms Proportion, harmony, balance, and beauty of form are terms invoked in dictionaries to explain the meaning of the word symmetry. But the formal study of symmetry must begin with a much simpler, more precise definition. Symmetry We will say that a set of objects has a symmetry if we know of a transformation rule that leaves the set unchanged. This is a formal definition of the word symmetry. One of the great discoveries of modern logic is that every fundamental definition must contain undefined terms. The words set, object, and transformation rule are the main undefined terms in this definition. For instance, you could define a set as a collection without regard to order. This is a good informal explanation of the word set, but it is not a formal definition, because what is the formal definition of collection, or of order ? We are worse off than before, because we have traded one undefined term for two others. It is an endless cycle, and it is best to recognize it as such, and agree upon the terms that will be accepted as undefined. The undefined terms of a logical system are not a limitation or a flaw; they are the source its power. Because they are undefined, you are free to interpret them in any way that you can make sense of them. Below, in Section 4.2 (Geometric Symmetry) and Section 4.3 (Algebraic Symmetry) we will give two different interpretations of the words object and transformation rule. The most creative thing that a person can do with a formal logical system is to find a new interpretation of its undefined terms; this has happened many times in the study of symmetry, and it will happen again. If you can find new interpretations for object and transformation rule, all the many rigorous results of symmetry theory apply to the new object, immediately illuminating and clarifying its properties. An outstanding example of this was the interpretation of spin as a new symmetric object, after it was discovered experimentally.
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_4, © Springer Science+Business Media, LLC 2009
29
Symmetry Theory
ing its properties. An outstanding example of this was the interpretation of spin as a new symmetric object, after it was discovered experimentally. Although it is useless to give formal definitions of “object” or “transformation rule", one can still discuss them informally. We will see two kinds of “objects” in this chapter, geometric objects and algebraic objects. A “transformation rule” must be something that would effect a change in most of the objects to which it applies, so that the few left unchanged by it are indeed very special ones that deserve the special adjective symmetric. So already we have a subtle insight: According to our formal definition, a symmetric set of objects is never a thing entirely on its own; it is symmetric only with respect to the transformation rules that humans formulate and lay upon it. When an object is “intuitively” symmetric, the rule is a subconscious one. When this process becomes conscious, with rules formulated according to an intent, we extend and refine the idea of symmetry in elegant and useful ways. We will see examples of this. But first, in this chapter, the basics.
4.2. Geometric symmetry 4.2.1. Links to background brush-up materials If you have done the Tutorial and you still feel a little rusty on vectors, matrices, and the Dot product, click here to go to a more detailed review at the end of the book. It is long and comprehensive, but the first parts of it are what you need.
4.2.2. Geometric meanings for the undefined terms We now take specific meanings for the undefined terms in the definition of symmetry. We let set of objects == a set of points in 3-dimensional space, and (to get started) we let transform == rotation or reflection of all the points. The center of gravity of the object is taken as the origin, and the rotation axes and the reflection planes must all contain the origin. Later this list of kinds of geometrical transforms will be extended, but these two simple kinds are enough to get us started. Repeating the definition of symmetry with these explicit meanings:
30
Geometric symmetry
"We will say that a set of geometric points has a symmetry if we know of a rotation or a reflection that leaves the point set unchanged." As described above, geometric symmetry is a matter of visualizing things in one's mind. But people vary a lot in the their visualizations, and visions are hard to describe convincingly to other people. To do mathematics with this definition, we must make use of the great discovery of René Descartes, that every mathematical point in 3-dimensions may be described as a triple of numbers {a,b,c}, called a vector. As we will see below, both rotations and reflections can be described by matrices of size 3 ´3 that multiply the vectors, using the row-by-column rule, or the Dot product. But visualization cannot and should not be supplanted, and a large part of Mathematica is devoted to graphics operators that turn lists of vectors into line drawings. So we have the best of both worlds: automated matrix multiplication for speed and absolute accuracy in calculation; and automated, exact perspective line drawings of the results, á la Leonardo, for visual understanding.
4.2.3. Reflection matrices Definition of “reflection” The “reflection” used in symmetry theory is not an optical reflection. However, it gets its name from the optical diagram of a light ray reflection, below. A ray from a street light bounces from the surface of a puddle and into an eye (or actually, into two stereoscopic eyes). The brain then uses the straight dashed extension of the eye's line of sight to interpret the position of the light as a point below the surface of the ground, at a depth equal to the height of the light above the ground. In Symmetry Theory, we forget about the eye and the true path of the ray, and take the relation between Source, Mirror, and Image as the “reflection”.
31
Symmetry Theory
Source Eye Mirror
Image Fig. 4.1 Optical reflection diagram
The U. S. Capitol building has reflection symmetry Consider an object that seems intuitively symmetric; for instance, the United States capitol building. Of course, it is not absolutely symmetric, but we idealize. If our formal definition cannot be applied to this idealized object, then it is nonsense; so let's begin here. What is a transformation rule that leaves the building unchanged? Think of a vertical plane passing through the center of the rotunda and dividing the whole building into equal halves, East Wing and West Wing. This is a mirror plane for the building, in the sense that the West Wing looks just like the reflection of the East Wing in a giant mirror placed in this plane. To sharpen this up, we establish two axes that lie in the mirror plane: vertical axis z running up through the center of the rotunda, and horizontal axis y running out the front door. Then x is an axis that runs perpendicular to the mirror plane, say, an East-West axis that runs in along the central hallway of one wing, through the rotunda and mirror plane, and out through a similar hall in the other wing. Consider a set of vectors that point to all the major architectural elements of the Capitol. One of its members, {x,y,z}, points from the origin to, say, the center of a window in the East Wing. Mirror symmetry means that the vector {-x,y,z} points to the center of a similar window in the West wing. The transformation rule that leaves the object unchanged is {x,y,z} ® {-x,y,z} In words, the rule is: Using an origin that lies in the mirror, in each architectural vector negate the component that is perpendicular to the mirror plane. This transform changes every East-wing vector into a West-wing vector, and vice-versa. If the two wings have true mirror symmetry, the vector set is the same before and after the transform (ignoring the order of the vectors, as always in a set). If there is no picture below, select and enter the little closed cell below.
32
Geometric symmetry
x East window Eye Rotunda y
Giant mirror edge view
West window
Fig. 4.2 Architectural symmetry
Ammonia has reflection symmetry There is an obvious analogy with molecules. Below we call up from the Molecules` package our specification of the ammonia molecule, in a format that we adopt as standard for all molecules. Each row specifies one atom by its element name, its Cartesian position in the molecule (in Angstroms), and its atom tag. MoleculeToList@"ammonia"D; % ColumnForm :N, :0, 0,
903 >, 25 000
81, C3v<>
:H, : 2500 , 0, - 10 000 >, 81<> 2469
:H, :- 2469 , 5000
1673
2469
:H, :- 2469 , 5000
3
5000 2469 5000
1673 , - 10 >, 82<> 000
3
,-
1673 >, 10 000
83<>
Note that we use no decimal approximations in the specification of molecules. The above is based on a four-digit experimental result for the ammonia molecule, but we have rationalized the Cartesian coordinates and used the exact irrational
3 to make the threefold rotational symmetry exact.
The operation of reflection in the x,z plane is performed by the Rule {x,y,z}®{x,-y,z}. This may be called either a reflection parallel to y, or a reflection in the xz plane. We generalize this definition : 33
Symmetry Theory
The operation of reflection in the x,z plane is performed by the Rule {x,y,z}®{x,-y,z}. This may be called either a reflection parallel to y, or a reflection in the xz plane. We generalize this definition : Reflection plane Given any plane, a Cartesian coordinate system can be defined such that two axes lie in the plane and the third is perpendicular. Reflection is the negation of the perpendicular coordinate. Is negation of the y axis a symmetry operation for the ammonia molecule, as given above? By inspection, one can see that it is. If the sign of each ycomponent is changed, the first two atoms are unchanged, while the H-atoms with tags 2 and 3 (the last two atoms in the list) merely exchange places. This changes the List, of course, because order is an important property of a List. But we regard the molecule as a set of atoms, not as a List of atoms, and order means nothing in a set. This idea is enforced by all our functions that operate on molecule objects. We have graphics functions, a molecular weight function, a center-of-mass function, an inertia tensor function, and others. But in all of them the output is independent of the order of the atoms in the molecule object. To see if two molecule objects represent the same molecule, apply Sort to each molecule and then apply the Equal question. If they are truly identical except for atom order, the answer will be True. Matrix formula for reflection in the y direction In a computer, an easy way to change vector {x,y,z} into vector {x,-y,z} is to multiply it by a simple matrix. If the vector is written as a column, it must be written on the right side of the matrix. The usual row-by-column multiplication rules are embodied by the Dot operator in Mathematica, written quite literally as a normal punctuation period between the matrix and the column vector. We apply MatrixForm to the result to have it written as a column 1 0 0 -1 0 0
x 0 0 . y z 1
MatrixForm
x -y z
In a molecule with four atoms, you can do all the atoms at once if the atom position vectors are written as the columns of a 3-by-4 matrix. 34
Geometric symmetry
In a molecule with four atoms, you can do all the atoms at once if the atom position vectors are written as the columns of a 3-by-4 matrix. x1 x2 x3 x4 1 0 0 0 -1 0 . y1 y2 y3 y4 z1 z2 z3 z4 0 0 1
MatrixForm
x1 x2 x3 x4 -y1 -y2 -y3 -y4 z1 z2 z3 z4
Matrix multiplication is an extremely fast operation, so even pictures with thousands of points can be transformed this way very quickly. Many of the computer graphics animations that you see in movies and television advertising are based on frame-by-frame multiplication of a 33 transform matrix (on the left) dotted into a 3 N point matrix (on the right ). This operation is so fast it can be done in real time in some movies that you see in computer games. Later, we will see a similar matrix scheme, of size (4 ´ 4).(4 ´ N), for translating and rotating at the same time. It is traditional to give all reflection matrices a name that starts with Σ. In the Symmetry` package we defined matrices Σx, Σy, and Σz , and in the preliminaries we made them equivalent to the subscripted forms Σx , Σy , and Σz : Map@MatrixForm, 8Σx , Σy , Σz
:
-1 0 0 0 1 0 , 0 0 1
1 0 0 0 -1 0 , 0 0 1
1 0 0 0 1 0 > 0 0 -1
Numerical example of molecule reflection We look at a real example. The {x,y,z} coordinates of the ammonia molecule can be brought up by the command RestPoints@"ammonia"D MatrixForm 0
0
2469 2500
0
- 2469 5000
2469
- 2469 5000
903 25 000 1673 - 10 000 3
5000 2469 5000
3
1673 - 10 000 1673 - 10 000
But above, the coordinates of each atom are written as a row. We need them as columns, which is easily done by the Transpose operator :
35
Symmetry Theory
ammoniaCoordinates = Transpose@RestPoints@"ammonia"DD; % MatrixForm 0
2469 2500
0
0
903 25 000
1673 - 10 000
- 2469 5000 2469
- 2469 5000
3
-
5000 1673 - 10 000
2469
3
5000
1673 - 10 000
Now we can multiply from the left by the reflection matrix Σy : reflectedAmmonia = Σy.ammoniaCoordinates ; % MatrixForm 0
2469 2500
0
0
903 25 000
-
1673 10 000
- 2469 5000 -
2469
-
- 2469 5000 3
2469
5000 1673 10 000
3
5000
-
1673 10 000
Columns 3 and 4 are both H atoms, and have traded places. But column order is meaningless (as long as both columns refer to the same kind of atom) so the molecule is unchanged. The technical language for this is that the atom set is invariant under the given transform. Pictures of symmetry and non-symmetry reflections We have defined an operator called ShowOperation which draws a before picture of any given molecule, extracts the rest points of its atoms as a 3N matrix, transforms them by the given symmetry matrix, and then draws an after picture of the molecule after transformation. Below, we ask it to use matrix Σy on the molecule "ammonia". We also include the option ViewPoint® {4,2,3}, which puts the viewing eye at this position in 3D space. The eye looks directly toward the origin, and the view that it sees is rendered in mathematically perfect perspective. We first make a Graphics3D object that shows what we want, but with quite a bit of unwanted white space around it. The 3D object cannot be cropped. So we Rasterize it to make it into a two-dimensional Graphics object, and crop it using PlotRange inside the Show operator.
36
Geometric symmetry
fig3 = ShowOperationAΣy , "ammonia", ViewPoint ® 84, 2, 3<, Style ® "TB", ImageSize ® 8300, 300<, Ticks ® NoneE; fig3R = Rasterize@fig3, ImageResolution ® 300D; Show@fig3R, PlotRange ® 8840, 270<, 8100, 230<<, ImageSize ® 8200, 100
Fig. 4.3 Ammonia with numbered atoms, before and after reflection in the z,x plane. H atoms 2 and 3 switch places. But they are identical, so the molecule is unchanged. This is symmetry.
The molecule looks the same before and after (except for atom labels, which don't count), so according to our definition Σy is a symmetry operation for the ammonia molecule- it is a transform that leaves the object unchanged. But to really understand this, you must also see an operation on a molecule that is NOT a symmetry operation: fig4 = ShowOperation@Σx , "ammonia", ViewPoint ® 84, 2, 3<, Style ® "TB", ImageSize ® 8300, 300<, Ticks ® NoneD; fig4R = Rasterize@fig4, ImageResolution ® 300D; fig4S = Show@fig4R, PlotRange ® 8840, 270<, 8100, 230<<, ImageSize ® 8200, 100
Fig. 4.4 Ammonia, before and after reflection in the y,z plane. The atoms moved, so y,z reflection is not a symmetry of ammonia.
Each atom “reflects through” the z,y plane (or stays put, if it lies in the plane). The molecule after looks quite different than before, so Σx is NOT a symmetry operation for this molecule.
4.2.4. Rotation matrices 37
Symmetry Theory
4.2.4. Rotation matrices Rotational symmetry Rotational symmetry is another common interpretation of the word “symmetry“; it is embodied by the rotunda and dome of the capitol, considered apart from the rest of the building. It has 24 identical segments, each with a little window and other features, so we say that it has “24-fold” rotational symmetry about a z axis that rises vertically through its exact center. Physically, we mean that if the dome were jacked up and turned by 2Π/24, the Capitol would be exactly the same before as after. As a public works project, this would certainly bring home the meaning of rotational symmetry to the entire nation. Our model ammonia molecule has a similar rotation symmetry. It is a little umbrella, where the umbrella handle is the z axis, and the blue N atom is at the top of the umbrella. But in this case the symmetry rotation is only a third of a turn. amm = Show@8AtomGraphics@"ammonia", AtomLabels -> FalseD, BondGraphics@"ammonia", 1.2, .015D<, Boxed -> FalseD; AxialViews@amm, ImageSize ® 8200, 200
Fig. 4.5 Complete information on the structure of ammonia.
38
Geometric symmetry
A matrix formula for rotation about the z axis Before we rotate whole objects, let us think about how to rotate a single mathematical point around the z-axis. We begin by writing a general Cartesian point {x,y,z} in cylindrical coordinates {r,Α,z}, taking the cylinder axis as the z axis. The general point before transformation is ptBefore = 8x, y, z< . 8x ® r Cos@ΑD, y ® r Sin@ΑD< 8r Cos@ΑD, r Sin@ΑD, z<
Before transformation, the point could be anywhere, as specified by the values of r, Α, and z. The final point, however, must be related to the initial point by a simple rotation through some angle Β about the z axis. This means that r and z must stay constant and the angle must change from Α to Α + Β. Thus we write ptAfter = ptBefore . Α ® Α + Β 8r Cos@Α + ΒD, r Sin@Α + ΒD, z<
TrigExpand rewrites trigonometric functions of sums, difference, or multiples of angles in terms of the individual angles. ptAfter2 = TrigExpand@ptAfterD
8r Cos@ΑD Cos@ΒD - r Sin@ΑD Sin@ΒD, r Cos@ΒD Sin@ΑD + r Cos@ΑD Sin@ΒD, z<
In this form we can reverse the original substitution, trading off Α and r in favor of the original x and y : ptAfter3 = ptAfter2 . 8r Cos@ΑD ® x, r Sin@ΑD ® y< 8x Cos@ΒD - y Sin@ΒD, y Cos@ΒD + x Sin@ΒD, z<
This is the position of the point after rotation, in terms of the original position {x,y,z} and the rotation angle Β. Each of the three vector components is linear in x, y, and z. Therefore, we can rewrite this expression as a rotation matrix times the original vector {x,y,z}. In fact, the matrix may be extracted by a handy operator called MatrixOfCo efficients. It takes two operands; first, a list of expressions, and second, a list of variables, in which the expressions must be linear. First, we try it on a purely mathematical example. Consider two expressions linear in x, y, and z. twoExpressions = 8 c11 x + c12 y + c13 z, c21 x + c22 y <;
The matrix of coefficients extracted by the operation 39
Symmetry Theory
The matrix of coefficients extracted by the operation
MatrixOfCoefficients@twoExpressions, 8x, y, z
K
c11 c12 c13 O c21 c22 0
Note that any missing variable is automatically assigned a zero coefficient, so the matrix is always rectangular. Now we are ready to extract the square matrix of coefficients for rotation about the z axis by angle Β : rotMat = MatrixOfCoefficients@ptAfter3, 8x, y, z
This is a beautiful result. It says that in order to rotate any point {x,y,z} around the z axis by angle Β, we simply left-multiply the point by this matrix. Let's check it, using the starting expression ptAfter3 above for the right side : x Cos@ΒD -Sin@ΒD 0 Sin@ΒD Cos@ΒD 0 . y z 0 0 1
==
x Cos@ΒD - y Sin@ΒD y Cos@ΒD + x Sin@ΒD z
True
Even better, the format matrix.oldVector == newVector is exactly the same as for reflection. If we keep at it, we can develop matrices representing all possible reflections and rotations. Perhaps it's obvious, but this format also means that we can rotate many vectors at once, just as we reflected many vectors at once, using formulas with column vector points, like x1 x2 x3 x4 Cos@ΒD -Sin@ΒD 0 Sin@ΒD Cos@ΒD 0 . y1 y2 y3 y4 z1 z2 z3 z4 0 0 1
40
GridForm
Cos@ΒD x1 Sin@ΒD y1
Cos@ΒD x2 Sin@ΒD y2
Cos@ΒD x3 Sin@ΒD y3
Cos@ΒD x4 Sin@ΒD y4
Sin@ΒD x1 + Cos@ΒD y1
Sin@ΒD x2 + Cos@ΒD y2
Sin@ΒD x4 + Cos@ΒD y4
z1
z2
Sin@ΒD x3 + Cos@ΒD y3 z3
z4
Geometric symmetry
Two-dimensional rotations (about an axis implicitly perpendicular to the page) must be x1 x2 Cos@ΒD -Sin@ΒD .K O GridForm y1 y2 Sin@ΒD Cos@ΒD
Cos@ΒD x1 - Sin@ΒD y1 Sin@ΒD x1 + Cos@ΒD y1
Cos@ΒD x2 - Sin@ΒD y2 Sin@ΒD x2 + Cos@ΒD y2
Standard notation for rotations
Cn
denotes a rotation by 2Π/n radians about an unspecified axis.
Cn, x
denotes a rotation by 2Π/n radians about the x axis.
C x @ΦD is a matrix for rotation by Φ radians about the x axis, and similarly for y and z. Does the Symmetry` package know this notation ? Subscripts are forbidden in packages, but in the Preliminaries we set some notational equalities that permit us to write Cx @ΦD GridForm 1 0 0
0 Cos@ΦD Sin@ΦD
0 -Sin@ΦD Cos@ΦD
right handed rotation Position your right hand with the thumb extended and pointing in the positive direction along the axis of rotation, and curl your fingers. The fingers then point in the sense of a right handed rotation. Another way of saying it: Right handed rotations are counterclockwise, as viewed from a point on the positive side of the axis of rotation, looking toward the origin. Right handed is meaningless if the axis of rotation does not have plus and minus ends. Thus, if an axis of rotation in a drawing is just a simple line with no indication of the positive end (such as a plus sign, or an arrowhead, or an axis name), then there is no way to know which sense of rotation is right handed. The undefined terms of the handedness definition are right hand and counter41 clockwise. This has given rise to some deep thoughts. What would you understand here if you knew nothing about hands or clocks? The definition rests only on human conventions, yet the world is full of handedness asymmetries; most
Symmetry Theory
indication of the positive end (such as a plus sign, or an arrowhead, or an axis name), then there is no way to know which sense of rotation is right handed. The undefined terms of the handedness definition are right hand and counterclockwise. This has given rise to some deep thoughts. What would you understand here if you knew nothing about hands or clocks? The definition rests only on human conventions, yet the world is full of handedness asymmetries; most notably in the realm of biomolecules. The electromagnetic force, that governs the structure of molecules, has no intrinsic handedness, so right- and lefthanded versions of handed molecules have exactly the same energy in all standard quantum chemical calculations. The energies split in a magnetic field, but the effect is very tiny for fields the size of the earth's. At a more fundamental level, the “weak” interaction, which does apply to electrons, is handed. But it is so small that it cannot influence chemistry. Yet the amino acids extracted from living materials are all 100% handed, and the handedness is always the same throughout all of biology. This asymmetry remains a mystery, one of the few that 20th century science failed to illuminate. Most scientists by now believe that the source of this asymmetry is not to be sought in physics, but in the extreme early stages of Darwinian evolution, when barely living polymer systems were first emerging from a primordial chemical soup. If mixed handedness ever existed, then some early evolutionary advantage developed in only one handedness, in a way that could not be adopted by the other. Perhaps it was a small polymer that could bind left-X (but not rightX) and convert it to something useful. So the organisms that had only right-X fell into a disadvantage, and dwindled to extinction. Rotations about the x-axis and the y-axis may be derived just like the zrotations, above. (This is an excellent exercise; try it!) The results are already in the Symmetry` package : Cy @ΒD MatrixForm Cos@ΒD 0 Sin@ΒD 0 1 0 -Sin@ΒD 0 Cos@ΒD
Cz @ΒD MatrixForm Cos@ΒD -Sin@ΒD 0 Sin@ΒD Cos@ΒD 0 0 0 1
42
Geometric symmetry
Numerical example of molecule rotation You need to see a numerical example to get the full meaning here. Above, we defined ammoniaCoordinates = Transpose@RestPoints@"ammonia"DD; ammoniaCoordinates MatrixForm 0
2469 2500
0
0
903 25 000
-
- 2469 5000 2469
- 2469 5000
3
-
5000
1673 10 000
1673 10 000
-
2469
3
5000
-
1673 10 000
The first column represents an atom is on the z axis, which must be the nitrogen atom. The other three columns are the H atoms. Now we rotate all the atom positions at once around the z axis by the matrix formula rotatedAmmonia = Cz@2 Π 3D.ammoniaCoordinates MatrixForm
0 0 903 25 000
- 2469 5000 2469
3
5000
-
1673 10 000
- 2469 5000 -
2469
-
2469 2500 3
0
5000 1673 10 000
-
1673 10 000
The nitrogen atom (first column) was unmoved because it lies on the axis of rotation. The rotation has switched the three H-atom columns around, but column order (atom order) is meaningless, so the molecule is unchanged. As expected, a three-fold rotation about z is a symmetry operation for ammonia. Pictures of symmetry and non-symmetry rotations ShowOperation@Cz@2 Π 3D, "ammonia", ViewPoint -> 80, 0, 4<, ImageSize ® 300D
43
Symmetry Theory
Fig. 4.6 Rotation of ammonia by a third of a turn IS a symmetry operation.
Without the labels, one cannot tell above that anything happened. This is a symmetry transform. Look at rotation by half a turn: ShowOperation@Cz@ΠD, "ammonia", ViewPoint -> 80, 0, 4<, ImageSize ® 300D
Fig. 4.7 Rotation of ammonia by a half turn is NOT a symmetry transform.
Here you do not need labels to see that something happened. This is NOT a symmetry transform.
44
Geometric symmetry
4.2.5. New symmetries from old If you know of two transforms that leave an object unchanged, then it must be true that applying first one and then the other also leaves the object unchanged. This simple idea has a very important consequence. Look at an example. ammoniaCoordinates MatrixForm 0
2469 2500
- 2469 5000
0
0
903 25 000
1673 - 10 000
2469
3
5000 1673 - 10 000
- 2469 5000 -
2469
3
5000
1673 - 10 000
If we apply first the reflection and then the rotation about z by a third of a turn, the calculation is Cz @2 Π 3D.IΣy .ammoniaCoordinatesM MatrixForm - 2469
0 0 903 25 000
5000
2469
3
5000 1673 - 10 000
2469 2500
0 1673 - 10 000
- 2469 5000
-
2469
3
5000
1673 - 10 000
The result is the same molecule, as it must be, though we have not seen this particular order of the H atoms before. Matrix multiplication is associative, so this is the same as ICz @2 Π 3D.Σy M.ammoniaCoordinates MatrixForm - 2469 5000
0 0 903 25 000
2469
3
5000 1673 - 10 000
2469 2500
0 1673 - 10 000
- 2469 5000 -
2469
3
5000
1673 - 10 000
This shows that the single new matrix, given by Cz @2 Π 3D.Σy MatrixForm - 12 3
3 2
0
2
1 2
0
0
0
1
is also a symmetry transform of the ammonia molecule. Later we will see that this matrix represents reflection in a line rotated by 1/3 turn from the y-axis. It is different from either of the other two that we have been considering, which 45 we repeat just below for comparison:
Symmetry Theory
is also a symmetry transform of the ammonia molecule. Later we will see that this matrix represents reflection in a line rotated by 1/3 turn from the y-axis. It is different from either of the other two that we have been considering, which we repeat just below for comparison: 8Cz @2 Π 3D MatrixForm, Σx MatrixForm< :
- 12 3
-
3 2
0 ,
2
- 12
0
0
0
1
-1 0 0 0 1 0 > 0 0 1
This illustrates an important principle: If you multiply any two matrices that are symmetry transform matrices of the same object, you get another symmetry transform matrix of that object. Another way of saying it: Two symmetries imply the existence of a third symmetry, which may be different from the first two, and which you may or may not have noticed directly.
4.3. Algebraic symmetry 4.3.1. Algebraic meanings for the undefined terms We now take specific meanings for the undefined terms in the definition of symmetry. We let object == algebraic expression, and we let transform == replacement of variables that belong to the expression. Repeating the definition of symmetry with these explicit meanings: "We will say that a set of algebraic expressions has a symmetry if we know of a replacement of variables that leaves the set unchanged." Replacement of variables is an operation that lies at the heart of Mathematica, but usually, it is NOT a symmetry transform. For instance, in the expression x3 we can replace x by -x if we write x3 . x ® -x -x3
The output is algebraically different from the input and there is no symmetry. When we say unchanged we mean it quite literally. Look at the following, perhaps the most famous of examples :
46
Algebraic symmetry
x2 . x ® -x x2
Now there, that is what we mean by symmetry in an algebraic expression. The output expression is EXACTLY the same as the input expression Or, as we will see, is algebraically equivalent to input expression.
4.3.2. Examples of algebraic symmetry Sine and cosine under x, y exchange Take a set of two expressions, the Cartesian expressions for sine and cosine, and then swap x and y : y x : , > . 8 x ® y, y ® x< x2 + y2 :
x
x2 + y2 y
, x2 + y2
>
x2 + y2
The second becomes the first and first become the second. The List is different, because the order has changed. But a set is a collection without regard to order, and the set is the same. From matrix to rule Every geometric symmetry transform can be described as either a matrix or as a replacement rule. Many transform matrices are tabulated in our Symmetry` package, and there is a simple way to turn them into rules. Here it is: Thread@8x, y, z< ® mat.8x, y, z< D
8x ® mat.8x, y, z<, y ® mat.8x, y, z<, z ® mat.8x, y, z<<
To see what Thread does, take it away and rerun. (It turns a 3D vector replacement into three 1D scalar replacements.) Matrix Σz is defined in the Symmetry` package : Σz MatrixForm 1 0 0 0 1 0 0 0 -1
The corresponding rule is 47
Symmetry Theory
The corresponding rule is
Thread@8x, y, z< ® Σz.8x, y, z< D 8x ® x, y ® y, z ® -z<
Later, when you are more familiar with the names of groups and elements, you can use a package operator to call them down by the name SymmetryRule. Call up its syntax statement (using the ?) and read it. Distance from the origin, under rotation This one illustrates a little different twist. We will show that the distance of a point from the origin is invariant under rotation about the origin. The original position is {x,y,z} and its distance from the origin is
x2 + y2 + z2 . We
rotate around the z axis by angle Α : Cz @ΑD.8x, y, z<
8x Cos@ΑD - y Sin@ΑD, y Cos@ΑD + x Sin@ΑD, z<
The corresponding rotational transform rules are
rotRule = Thread@8x, y, z< ® Cz @ΑD.8x, y, z< D
8x ® x Cos@ΑD - y Sin@ΑD, y ® y Cos@ΑD + x Sin@ΑD, z ® z<
Now apply these rules to the radius formula : transformedRadius =
x2 + y2 + z2 . rotRule
z2 + Hy Cos@ΑD + x Sin@ΑDL2 + Hx Cos@ΑD - y Sin@ΑDL2
This certainly does not look the same before and after replacement. The point of this example is, initial appearance is not the criterion. The criterion is whether, after replacement, one can use valid algebraic replacement rules to return it to the original form : Map@TrigExpand, transformedRadiusD x2 + y2 + z2
There it is. As we knew, the radius expression is indeed invariant under rotation.
48
Algebraic symmetry
Coulomb field of one H nucleus The algebraic symmetry of Hamiltonian operators is of central importance in molecular physics. If the Hamiltonian Hx,y,z is symmetric under a given
algebraic transform, then the ground state of the molecule Ψ0 @x, y, zD (but not necessarily higher states!) will be symmetric under the same transform. We again take the ammonia molecule as our example. We look first at the potential energy part of the Hamiltonian. The potential energy of an electron at {x,y,z} due to a proton at the origin is given (in x2 + y2 + z2 . If the proton is not at the origin, but at
atomic units) by -1/
{a,b,c}, this energy becomes 1/ Hx - aL2 + Hy - bL2 + Hz - cL2 . We can make this into a function of the vector {a,b,c} : Clear@CoulombEnergyD; CoulombEnergy@8a_, b_, c_
Hx - aL2 + Hy - bL2 + Hz - cL2 We test the function out:
CoulombEnergy@8x1 , y1 , z1
1
Hx - x1 L2 + Hy - y1 L2 + Hz - z1 L2
Coulomb field of all the H nuclei in ammonia In our ammonia molecule the three H atoms are at ptH1 = ptH2 = ptH3 = 8ptH1,
RestPoints@"ammonia"DP2T; RestPoints@"ammonia"DP3T; RestPoints@"ammonia"DP4T; ptH2, ptH3< ColumnForm
:- 2469 , 5000
2469
1673 : 2469 , 0, - 10 > 2500 000
:- 2469 ,5000
3
5000 2469 5000
1673 , - 10 > 000
3
1673 , - 10 > 000
The three Coulomb energy expressions may be written in a list by the command 49
Symmetry Theory
The three Coulomb energy expressions may be written in a list by the command threeEnergies = 8CoulombEnergy@ptH1D, CoulombEnergy@ptH2D, CoulombEnergy@ptH3D< ExpandAll :-
1 , 20 066 861 20 000 000
-
2469 x 1250
2
2
+x +y +
1673 z 5000
2
+z
1
-
, 20 066 861 20 000 000
+
2469 x 2500
+ x2 -
2469
3 y
2500
+ y2 +
1673 z 5000
+ z2 >
1
20 066 861 20 000 000
+
2469 x 2500
+ x2 +
2469
3 y
2500
+ y2 +
1673 z 5000
+ z2
Rotational symmetry of the Coulomb field Now we want to see what happens to these expressions when we rotate the coordinate {x,y,z} by one-third of a turn. We already have this transform above in terms of the general rotation angle Α, so we just replace Α appropriately. oneThirdTurn = HrotRule . Α ® 2 Π 3L :x ® -
x 2
-
3 y
,y®
2
3 x 2
-
y
, z ® z>
2
Perform the replacements : rotatedEnergies = threeEnergies . oneThirdTurn ExpandAll
50
Algebraic symmetry
:-
1 , 20 066 861 20 000 000
+
2469 x 2500
+ x2 +
2469
3 y
2500
+ y2 +
1673 z 5000
+ z2
1
-
, 20 066 861 20 000 000
-
2469 x 1250
2
2
+x +y +
1673 z 5000
2
+z
>
1
20 066 861 20 000 000
+
2469 x 2500
+ x2 -
2469
3 y
2500
+ y2 +
1673 z 5000
+ z2
A very interesting thing has happened: each Coulomb expression has been transformed into one of the other two. 8threeEnergiesP1T == rotatedEnergiesP2T, threeEnergiesP2T == rotatedEnergiesP3T, threeEnergiesP3T == rotatedEnergiesP1T< 8True, True, True<
Clearly, the sum of the three is the same before and after this transform, so the sum is an algebraic expression that is symmetric under rotation by one third of a turn. Reflection symmetry of the Coulomb field The Coulomb energy should also be symmetric under the reflection transform y ® -y. You can see it by inspection, but we make it explicit: threeEnergiesReflected = threeEnergies . y ® -y ExpandAll
51
Symmetry Theory
:-
1 , 20 066 861 20 000 000
-
2469 x 1250
2
2
+x +y +
1673 z 5000
2
+z
1
-
, 20 066 861 20 000 000
+
2469 x 2500
2469
+ x2 +
3 y
2500
+ y2 +
1673 z 5000
+ z2 >
1
20 066 861 20 000 000
+
2469 x 2500
2469
+ x2 -
3 y
2500
+ y2 +
1673 z 5000
+ z2
Comparing the reflected expression to the original, we see that the last two terms have been transformed into each other, while the first remains invariant. Again, the sum will be invariant, so y-reflection is a symmetry transform for it.
4.3.3. Visualization of algebraic symmetry If all this is true, the contour plot of this function should show a threefold rotational symmetry and a y-reflection symmetry. This is easy to verify. We add up the three expressions, to give the total potential energy of the electron due to the three H nuclei, and (preparing to make a 2-D graphic) we specialize to the plane z == 0 : energyH3z0 = Apply@Plus, threeEnergiesD . z ® 0 1
20 066 861 20 000 000
-
2469 x 1250
2
2
+x +y 1
20 066 861 20 000 000
+
2469 x 2500
+ x2 -
2469
3 y
2500
+ y2
1 20 066 861 20 000 000
+
2469 x 2500
+ x2 +
2469
3 y
2500
+ y2
The Apply operator, as used above, is worth noting in detail. We take a simple example and write it out in FullForm, to show that Apply is an operator that changes the head of an expression :
52
Algebraic symmetry
Apply@Plus, List@A, B, CDD A+B+C
and can therefore be used to add up the items in a List. Returning to energy H3z0 function, we make a contour plot for it: ContourPlotBenergyH3z0, 8x, -2, 2<, 8y, -2, 2<,
PlotPoints -> 40, BaseStyle ® "TR", Axes -> True,
AxesLabel -> 8"x", "y"<, Epilog -> :Thickness@.005D, Red, Line@88-2, 0<, 82, 0<, :-1, -
LineB::1,
3 >, :-1,
3 >>F,
3 >>F>, ImageSize ® 200F
y 2
1
x
0
1
2
2
1
0
1
2
Fig. 4.8 Cross section of the potential of an electron in the three protons of the ammonia molecule, taken through the center of gravity, perpendicular to the threefold axis.
The potential does indeed have the expected symmetries: a threefold rotational symmetry, as well as a reflection symmetry in the red horizontal line. This plot also shows two other symmetries, reflections in the two blue lines rotated ± 1/3 turn from the red horizontal line. You can see rather intuitively that if any object has a reflection plane that contains a threefold rotation axis, it has to have the two other similar reflection planes. Finding all the symmetries implied by a small number of symmetries is an important part of group theory that we will study in detail in Chapter 15 (Make Matrix Group).
4.4. Summary and preview 53
Symmetry Theory
4.4. Summary and preview We have considered two basic kinds of symmetry, reflection and rotation, focussing on the symmetry transforms themselves, in two forms. 1. Geometric symmetry transforms were carried out by matrix multiplications. 2. Algebraic symmetry transforms were carried out by substitutions of variables. In the next chapter (Axioms) we will introduce the concept of a mathematical group; in the chapter after that we will see many examples of groups; then in Chapter 7 we will prove the fundamental theorem of symmetry theory; namely, that all the symmetry transforms of any symmetric object must form a group.
4.5. End Notes Atom tags The full atom tag is a list. Its first (and often only) element is an integer that distinguishes each atom from others of its own kind. This integer is automatically printed in the center of each atom by the molecular graphics functions. But in complicated molecules, such as proteins, the atom tag list can include other information, such as to which amino acid the atom belongs, or to which chain of a protein complex. Specialized molecular graphics functions can extract this information to color whole amino acids, or whole chains.
54
5. Axioms of group theory Preliminaries
5.1. Undefined terms in the axioms In this book, we will be concerned almost exclusively with groups of symmetry transforms. But the “group” is one of the most general concepts in mathematics, and we must begin with the axioms of group theory, stated in a form that applies to all kinds of groups. We consider a set of elements {A,B,C,… } and an operator written as Ä which takes two members of the set as its arguments, in expressions like A Ä B. The elements of the set form a “group under Ä” if the conditions of Axioms 1 through 4 are met. Comments: (1) The terms elements and operator are undefined. They can take on any meanings for which they make sense. (2) The set of elements may be finite or infinite in number. (3) When A Ä B goes to the Mathematica processor, it is automatically translated into a square bracket form like f[A,B], where the symbolic Ä has become an explicit f, like Times, Dot, Plus, or Permute. In all these cases, A and B will be simple, definite things that the operator can work on. (4) The number of elements in a group is called its group order. This has absolutely nothing to do with sorting order. The group elements may be named or listed in any sorting order. (5) There is some confusion whether the elements {A,B,C,… } must all be different, or whether repeats are allowed. This confusion is tolerated because it affects nothing but the language with which some of the theorems are stated. Usually we will mean the elements to be distinct, but when they are not we will call the group a redundant group. Symmetry groups are associated with groups of matrices called representations, and representations are often redundant groups.
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_5, © Springer Science+Business Media, LLC 2009
55
Symmetry Theory
5.2. The four axioms 5.2.1. Closure Axiom
Axiom 1. If M and N are members of a group under Ä, the operation M Ä N yields a unique value, which is also a member of the group. Comments: (1) No matter what the operator Ä actually is, it is conventionally called multiplication. For instance, we will often specify that the elements of the group are matrices and that the operation is matrix multiplication, In this case M Ä N will be carried out as M.N , which in Mathematica is Dot[M,N]. Or M and N might be ordered lists, and M Ä N could mean a reordering of list M according to instructions in list N. This is permutation, carried out in Mathematica as Part[M,N]. (2) “Multiplication” may be commutative or non-commutative. That is, it may or may not be true that M Ä N is always identical to N Ä M. For numbers under numerical multiplication, it is true. But when Ä is matrix multiplication or permutation of a list, the two products are generally different. Commutative groups are often called Abelian groups, after the Norwegian mathematician Niels Hendrik Abel (1802- 1829), forever young.
5.2.2. Unit Element Axiom
Axiom 2. Every group contains a unit element E, such that for every member X of the group, X Ä E == E Ä X == X. Comments: (1) The letter E comes from the German word Einheit, meaning unity. This notation is so firmly embedded in group theory that it absolutely cannot be changed. However, in Mathematica the CapitalE is defined as the exponential ã. Rather than disrupt this system, we will use a string “E” for the E of group theory. In Input cells it makes a big difference : 56
The four axioms
8E, "E"< N 82.71828, E<
(2) For groups of numbers under numerical multiplication, E is indeed the number 1. For groups of matrices, E is the unit matrix (with 1's down the diagonal and zeroes everywhere else). (3) For a more perverse example, consider the set of all numbers with Ä as numerical addition. Here the number zero plays the role of the unit element E, because 0 + n = n + 0 = n. (4) When listing the members of a group, the unique element E is conventionally given first.
5.2.3. Inverse Axiom
Axiom 3. For every element X of the group, there is an element Y in the group such that X Ä Y == Y Ä X == E . Comments: (1) Elements X and Y are said to be mutually inverse, and you may write X as Y -1 , or Y as X-1 . It is allowed that X and Y be the same. For instance, setting X ® E in Axiom 3, above, we see an instant proof that Y has to be E, so that E is its own inverse. (2) The algorithm for finding the inverse depends on what the elements are. For numbers under Times, the inverse of x is 1/x, as carried out by long division. For matrices under Dot, it is the matrix inverse operation, as carried out by the Mathematica operator Inverse[mat]. (3) This axiom excludes 0 from every group of numbers under multiplication, just as it excludes singular matrices (matrices that have no matrix inverse) from all groups of matrices under Dot.
5.2.4. Associative Axiom
Axiom 4. For any three elements A, B, and C of the group, it must be True that A Ä(B Ä C)) == (A Ä B)Ä C. Comments: (1) This property of the operator Ä is called associativity.
57
(2) This statement must be read in the light of the universal convention that at each step in an evaluation, only the innermost groupings are evaluated. Thus, in
Symmetry Theory
Comments: (1) This property of the operator Ä is called associativity. (2) This statement must be read in the light of the universal convention that at each step in an evaluation, only the innermost groupings are evaluated. Thus, in A Ä (B Ä C) , the inner B Ä C evaluates as some D, then A Ä D is evaluated. But in (A Ä B) Ä C , the inner A Ä B evaluates first as some F, then F Ä C is evaluated. (3) Every operator must be tested for associativity according to its own properties. Associativity is a well known property of numerical multiplication, and of matrix multiplication. (4) Because of associativity, the triple product A Ä B Ä C is uniquely defined, and does not really need any grouping. (5) This axiom excludes numerical division as a possible group operation, because, for example, 8/(4/2) is 4, whereas (8/4)/2 is 1.
5.2.5. Coda These axioms are surprisingly rich in content. All of the many subtle theorems of abstract group theory trace back to these four statements and to nothing else. The terms “class”, “subgroup”, “irreducible representation”, and “character” do not occur in the axioms. Yet all these concepts are defined only in terms of language in the axioms, and all their properties are logical consequences of the axioms. There are also surprisingly many different kinds of mathematical objects that form groups. In the next Chapter, we will look in detail at several of them.
58
6. Several kinds of groups Preliminaries
6.1 Numbers under Times 6.1.1 Groups and subgroups of numbers All complex numbers (excluding zero, which has no inverse) form a group under Times. We have already mentioned the relevant properties in the Comments following each axiom. Further, certain finite subsets of the complex numbers also form groups. Subgroup If G is a group and H is a subset of G that is also a group, we say that H is a subgroup of G . Now you should use these concepts on your own. This will carve them into the stone of your mind.
6.1.2 Some practice questions (1) Which of the following is false? (The operator is Times in all cases.) (a) The real numbers are a subgroup of the complex numbers. (b) The rationals are a subgroup of the reals. (c) The integers are a subgroup of the rationals. (d) There is one finite subgroup within the integers. If you can't see which statement is false, then after really, really trying, click here. (2) The numbers 1 and -1 form a group under Times. Prove that if another real number is joined in, it is no longer a group. When you have it, click here to see a standard proof. (3) What is the unit element for the group of all complex numbers under Times? What is a simple expression for the inverse of a complex number, in terms of the number itself? Don't click here; this is too easy. (4) Many finite sets of complex numbers form groups. But they are all somewhat similar. The idea is a straightforward extension of the group {1,-1} for the reals. It will come to you if you start by thinking about whether successive it.. W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, 59 DOI 10.1007/b13137_6, © Springer Science+Business Media, LLC 2009
Symmetry Theory
the reals. It will come to you if you start by thinking about whether successive powers of a given complex number migrate toward the origin, or away from it.. If, after serious effort, you still need help, click here.
6.2 Matrices under Dot 6.2.1 All nonsingular 2 ´2 matrices All square matrices of the same size (excluding singular matrices, which have no inverse) form a group under Dot, the matrix multiplication operator. We make a detailed examination of all the axioms, for 2 ´2 matrices : Axiom 1. Closure K
a b e f O.K O GridForm c d g h ae+bg
af+bh
ce+dg
cf+dh
The product is another 2-by-2 matrix. This by itself is not quite enough to show closure for nonsingular matrices. We must also show that the product of two nonsingular matrices is nonsingular. This has to be true, because of two facts: (1) Det[A]==0 if and only if matrix A is singular (has no inverse), and (2) Det[A.B] == Det[A]*Det[B]. This is easily verified for the 2 ´2 case : mat1 = K
a b e f O; mat2 = K O; c d g h
Det@mat1.mat2D == Expand@Det@mat1D Det@mat2DD True
Since we used no numerical values in the matrices, this is a general proof for the 2 ´2 case : If neither Det[A] nor Det[B] vanishes, then Det[A.B] cannot vanish either. Therefore non-singularity comes down in the bloodline of 2 ´2 matrices, and Axiom 1 is satisfied. Axiom 2. Unit element We test the matrix K element :
60
1 0 O to see if it has the properties required of a unit 0 1
Matrices under Dot
K
1 0 a b a b 1 0 a b O.K O == K O.K O == K O 0 1 c d c d 0 1 c d
True
That True proves it. Axiom 3. Inverse Take the inverse of a general 2-by-2 : InverseBK ::
d -b c + a d
a b OF c d
,-
b -b c + a d
>, :-
c -b c + a d
a ,
-b c + a d
>>
This fails only if the denominator a d - b c = 0. But this is the determinant, DetBK
a b OF c d
-b c + a d
and matrices with zero determinant are excluded by definition. Axiom 4. Associativity of the Dot operator Try it, using three perfectly general 2 ´2 matrices : ExpandB K
a b e O.KK c d g a b e ExpandBKK O.K c d g
f i j O.K OOF == h k m f i j OO.K OF h k m
True
All the axioms are satisfied; therefore the set of all nonsingular 2 ´2 matrices form a group, q.e.d.
6.2.2 All unitary 2 ´2 matrices It will turn out that all symmetry transform matrices have determinant +1 or -1. These are called unitary matrices. If Det[A]= ±1 and Det[B]= ±1, then Det@A.BD = Det@AD Det@BD = ± 1. This proves that unitarity comes down in the bloodline. Therefore the subset of unitary 2 ´2 matrices form a group within the group of all nonsingular 2 ´2 matrices. This is your first example of the general concept of subgroups. The unitary matrices are a subgroup of the nonsingular matrices.
6.2.3 All nonsingular n ´n matrices 61
Symmetry Theory
6.2.3 All nonsingular n ´n matrices The results above can be extended to square matrices of any size by an inductive proof : Assume Det@A.BD = Det@AD Det@BD for matrices of size n ´ n. Use this to prove it for matrices of size (n+1) ´(n+1). Don't use any special case, such as n=2. It is important to prove it for the general n. Remember expansion by minors? Use it on the expression Det@AD Det@BD for matrices of size (n+1) ´(n+1). Expand by minors along the top row of each matrix, giving everything in terms of n ´n matrices. Then work with just one term from each expansion. The relation holds term-by-term, so you will have shown that IF it is true for n ´n matrices THEN it must be true for (n+1) ´(n+1) matrices. When you have it for the general n, reason as follows: We know by direct calculation that non-singularity comes down in the bloodline for n=2. Therefore it is true for n=3 . Therefore, it is true for n=4. And so on ... . q.e.d This finishes the proof that all nonsingular matrices of size n ´n form a group, whatever n may be.
6.2.4 All unitary n ´n matrices The inductive proof in 6.2.3 (All nonsingular n ´n matrices) can be applied without change to 6.2.2, showing that all unitary n ´n matrices form a group.
6.3 Axial rotation groups In Chapter 4 we showed that in three dimensions, rotation about the z axis is performed by the matrix Cz @ΦD MatrixForm Cos@ΦD -Sin@ΦD 0 Sin@ΦD Cos@ΦD 0 0 0 1
Cutting back to two dimensions, we define R@Φ_D := K
Cos@ΦD -Sin@ΦD O Sin@ΦD Cos@ΦD
It is easy to show that all the 2 ´2 R matrices produced as Φ runs around the whole circle form a group under Dot, called the “axial rotation group". 62
Axial rotation groups
It is easy to show that all the 2 ´2 R matrices produced as Φ runs around the whole circle form a group under Dot, called the “axial rotation group". H* 1, Closure *L True
H* 2, Identity *L True
H* 3, Inverse *L
R@aD.R@bD == HR@a + bD TrigExpandL R@0D == 881, 0<, 80, 1<< HR@aD.R@-aD TrigExpand L == R@0D
True
(* 4, Associative *) Always True for Dot The name “axial rotation group” is symbolized by physicists and chemists as C¥ , or by mathematicians as SO(2), meaning SpecialOrthogonal(2D). These matrices are Orthogonal because their transposes are their inverses R@ΦD.Transpose@R@ΦDD TrigExpand 881, 0<, 80, 1<<
and they are Special because any closed curve in the plane has the same area before and after any rotation.
6.4 Permutations under Permute 6.4.1 About permutations Exchange of identical particles, both electrons or nuclei, is an important symmetry operation of the molecular Hamiltonian. The labels that distinguish the particles are just the first n integers, and the order of this list changes as particles are exchanged. But this is exactly what mathematicians call a permutation. Permutation A permutation of length n is a List containing the first n integers, in any order. Mathematica has a fast and simple way of using a permutation as an instruction for rearranging a list of n objects. It is the Part operator. Its simplest use is just to pull one item out of a List :
63
Symmetry Theory
Part@8a, b, c<, 2D b
More often this is written as 8a, b, c
But Part also responds to a list of addresses: 8a, b, c
In fact it has permuted the list {a,b,c} according to the instructions in {2,3,1}. Going straight down the list of integers, it first took item #2; then it took item #3, then it took item #1. This gets more interesting when the first list is also a permutation of the same integers : 83, 1, 2
Now we have two objects combining to produce a third of the same kind. This sounds like it could be a group operator. We call the group operator Permute, and define it by the statement Permute@permutee, permuterD := permuteePpermuterT Try it out :
Permute@83, 1, 2<, 83, 2, 1
Stare at this until you see exactly what happened.
6.4.2 Permute satisfies the axioms We will now show that Permute can be the operator for a group. Closure There are only n! permutations of the first n integers, so the permutee, the permuter and their product are all members of the same finite set. There is no way the permutation operation can wander off to infinity. It only hops around among the n! possibilities, or some subset thereof. Closure is assured. Unit element The unit element is the list of the first n integers in natural order. It must be tested in both positions. First we try it as the permuter, then as permutee : 64
Permutations under Permute
Unit element The unit element is the list of the first n integers in natural order. It must be tested in both positions. First we try it as the permuter, then as permutee : unit = 81, 2, 3, 4, 5<; perm = 83, 2, 5, 1, 4<; 8Permute@unit, permD == Permute@perm, unitD == perm< 8True<
It works as a unit element should: E Ä P = P Ä E = P . Inverse There is a package operator that finds the inverse of any permutation. First we demonstrate it, then we discuss it. Again let perm = 83, 5, 1, 2, 4<;
and ask for its inverse: permInv = InversePermutation@permD 83, 4, 1, 5, 2<
Does permInv have the fundamental properties of an inverse?
8Permute@perm, permInvD, Permute@permInv, permD< 881, 2, 3, 4, 5<, 81, 2, 3, 4, 5<<
Yes! It works as it should: P Ä P-1 = P-1 Ä P = E . If it walks like an inverse and talks like an inverse, it is an inverse. How does the InversePermutation operator work? It does exactly what a human would do. (To avoid complicated general notation, we work on an example.) If you need the inverse of {3,5,1,2,4} you think to yourself: I want the permutation that puts this in natural order. So I take the third one (the 1) first, the fourth one (the 2) second, etc. Working it out in your head, you should come up with {3,4,1,5,2}, exactly as calculated above. But there is a Position operator that can automate this thought process. Try it on perm = {3,5,1,2,4} : Position@perm, 3D 881<<
Yes, the 3 is in position 1. Try some others on your own. We can define a function named permPosition that does this for element n of the example perm : permPosition@n_D := Position@perm, nD; Try it out:
65
Symmetry Theory
permPosition@4D 885<<
It says that 4 is in the 5th position of perm. This is true. So we just Map our new operator onto the integers in natural order : permInverseRaw = Map@permPosition, 81, 2, 3, 4, 5
Remember, perm was {3,5,1,2,4}. So the result above says: the 1 is in 3rd place, the 2 is in 4th place, etc. That is what we want, except for all those curly brackets. Fortunately, there is an operator called Flatten that takes any multiply bracketed object and removes all interior brackets, turning it into a simple List : automatedInv = permInverseRaw Flatten 83, 4, 1, 5, 2<
Is this the inverse that we found at the top by thinking it out, or by using InversePermutation ? automatedInv == permInv True
So it worked. But remember, this is not a formal proof, only an example. On your own Think about how you could turn this example into a general proof. Associativity Numerical examples are not proofs, but they can be suggestive. Let aPerm = RandomPermutation@16D
814, 9, 13, 8, 6, 12, 1, 2, 15, 7, 4, 10, 11, 5, 3, 16<
bPerm = RandomPermutation@16D
87, 13, 3, 6, 5, 12, 10, 11, 15, 16, 9, 4, 1, 8, 2, 14<
cPerm = RandomPermutation@16D
810, 14, 8, 13, 6, 4, 1, 7, 9, 16, 12, 5, 3, 15, 2, 11<
Below, the red pairs are calculated first. If Permute is associative, the triple products will be the same:
66
Permutations under Permute
Permute@aPerm, Permute@bPerm, cPermDD == Permute@Permute@aPerm, bPermD, cPermD True
If you ever find an aPerm, bPerm, and cPerm that produce different results above, please send them, with full details, to the American Mathematical Society, 201 Charles St., Providence, RI, USA Phone (401) 455-400, Fax (401) 331-3842. They get a lot of crackpot stuff and they will know what to do. The associative relation Permute[a,Permute[b,c]]==Permute[Permute[a,b],c] is a famous relation, and a true one, but no quick and easy proof is known. Bogus proofs of it abound, some published under very big names. If you are offered a quick and easy proof, try this: Substitute Divide for Permute, and see if the proof still seems to hold. 8Divide@a, Divide@b, cDD, Divide@Divide@a, bD, cD< :
ac
a ,
b
bc
>
Now there is a rigorous and complete proof that Divide is not associative. If you have a “ proof ” that it is associative, think again. Probably the clearest valid proof that Permute is associative follows this sketch: First prove that there is a one-to-one correspondence between permutations and permutation matrices (aPerm « aMat, bPerm « bMat) (click here), and then that Permute[aPerm,bPerm] corresponds to Dot[aMat,b Mat]. Since we know that matrices are associative under Dot, it follows that permutations are associative under Permute.
6.5 Fruit flies under reproduction
(a non-group)
A bottle of fruit flies does not form a group under the operation of biological reproduction. Biological reproduction gives meaning to the closure expression flyA Ä flyB = flyC, but many things are missing. Thinking of them all in detail, axiom by axiom, is an excellent exercise. Try it, then click here.
67
Symmetry Theory
6.6 End Notes 6.6.1 The false claim The false claim is (c). The integers do not form a group under Times because the inverse of an integer is not an integer (except in two special cases; namely, 1 and -1).
6.6.2 Real numbers Consider the set {1,-1,a}, where a is any other real number. The closure axiom says the set must contain a2 if it is to be a group under Times. But it doesn't, so it isn't. Depending on the value of a, absolute values of further powers grow steadily larger or steadily smaller, so closure is never possible.
6.6.3 Unit and inverse of complex numbers The unit element of the complex numbers under Times is 1+ ä*0 . In other words, it is just the usual 1 itself. The inverse of a + ä*b is Ha - ä * bL Ia2 + b2 M. If you don't believe it, multiply it out. You will see.
6.6.4 Finite groups of complex numbers The "nth roots of unity" are a set of n complex numbers that form a group under multiplication Starting at {1,0} in the complex plane, they are regularly spaced around the unit circle by 2Π/n radians. Powers of any number inside the unit circle move steadily closer to the origin; outside, they move steadily away from the origin. But powers of numbers on the unit circle stay on the unit circle. We generate the five fifth roots of unity : soln = SolveAu5 == 1, uE N;
roots5 = soln . Hu ® r_L ® r Flatten
81., -0.809017 - 0.587785 ä, 0.309017 + 0.951057 ä, 0.309017 - 0.951057 ä, -0.809017 + 0.587785 ä<
We used a little tricks above. The output of Solve is a list of Rules, not a list of numbers, but we converted it to a list of numbers by a pattern-matching trick /.(u®r_)®r. Take a look at the Argand diagram (a plot in the complex 68 plane) for these numbers :
End Notes
We used a little tricks above. The output of Solve is a list of Rules, not a list of numbers, but we converted it to a list of numbers by a pattern-matching trick /.(u®r_)®r. Take a look at the Argand diagram (a plot in the complex plane) for these numbers :
Imaginary 1
-1
1
Real
-1 Fig. 6.1 The five red dots are the fifth roots of unity.
Take the fifth power of each one, just to make sure: roots55 ChopInteger 81, 1, 1, 1, 1<
Look at this step by step to see the function of all its parts. First look at roots5, then at roots55 , then with ChopInteger.
6.6.5 Fruit flies 1. The Closure Axiom is not really fulfilled, because flies are either male or female, and the expression is True only for (male fly)Ä(female fly) = fly. 2. The Unit Axiom might in an incomplete sense be fulfilled by a peculiar flyE in which every gene is recessive. Then as far as the phenotype is concerned, flyA Ä flyE = flyA . But although the offspring might look the same as flyA, it would not really be the same; it would have a lot more recessive genes. 3. Given flyA, is there a flyAinverse such that flyA Ä flyAinverse always yields flyE, with all-recessive genes? This might happen once in a zillion tries, (or it could happen more quickly under artificial selection) but Mendelian inheritance is probabilistic, and it could not happen repeatably for any given flyA. 4. The associative axiom definitely does not hold, because (flyA Ä flyB)Ä flyC has half its genes from flyC, whereas flyA Ä(flyB Ä flyC) has only a quarter of its genes from flyC.
69
Symmetry Theory
4. The associative axiom definitely does not hold, because (flyA Ä flyB)Ä flyC has half its genes from flyC, whereas flyA Ä(flyB Ä flyC) has only a quarter of its genes from flyC. Too bad. Group theory just cannot help with Mendelian genetics.
6.6.6 Permutation matrices We must show that there is a one-to-one correspondence between permutations and permutation matrices. Begin by constructing a permutation matrix Pmat, an n ´n matrix that multiplies leftward into an ordered List of n objects to produce the required permutation of those objects. Totally general notation for this gets confusing, so we simply take an example. What is the permutation matrix that changes {a,b,c,d} into {b,c,d,a} ? We define it as the matrix Pmat that obeys 8a, b, c, d<.Pmat == 8b, c, d, a<
(6.1)
You might prefer that the left side be Pmat.{a,b,c,d}, but we have a reason to put Pmat on the right, and we stick firmly with it. We can solve this for Pmat using the MatrixOfCoefficients operator : MatrixOfCoefficients[exprs,vars] returns matrix MC, where MC.vars = exprs. It may fail if the vars are not simple symbols, and it will fail if the exprs are not linear in the vars.
Actually this is not exactly what we want. We would prefer an MC such that vars.MC == exprs, but we can get the same thing if we simply apply a Transpose to the result of this operator. Pmat = MatrixOfCoefficients@ 8b, c, d, a<, 8a, b, c, d
0 0 1 0
0 0 0 1
1 0 0 0
Permutation matrices are easy to recognize at a glance: they must be all zeroes except for a single 1 in each row and column. Make sure it really works: 0 1 8a, b, c, d<. 0 0
70
0 0 1 0
0 0 0 1
1 0 0 0
== 8b, c, d, a<
End Notes
True
We have an operator that converts a single permutation into a single matrix, so the correspondence permutation ® matrix is always one-to-one, What about the reverse correspondence, matrix ® permutation? It is sitting right up above. Given any permutation matrix, Dot it leftward into the unit permutation, and the answer is the permutation that corresponds to the matrix. So the correspondence permutation matrix is one-to-one both ways. For the closure axiom to hold we need to show that the product of any two permutation matrices is a permutation matrix. In other words, the property of being a permutation matrix must come down in the bloodline of matrices. The question is : If pMatA and pMatB are permutation matrices, and if pMatA.p MatB is pMatAB, can we be sure that pMatAB is a permutation matrix? We can settle this easily using the correspondence just established. Start with two permutations A and B, and find their product. Then convert all three permutations to permutation matrices using permToMat. This guarantees that pMatAB is a permutation matrix. Finally, test the dot product relation to see if it is true. We diagram this process below : permA Ä permB ¯ ¯ pMatA . pMatB
==
permAB ¯ =?= pMatAB
Do a concrete example : Let
permA = 82, 5, 3, 1, 4<; permB = 83, 2, 4, 5, 1<;
The operation permA Ä permB is implemented as permAB = Permute@permA, permBD 83, 5, 1, 4, 2<
Now convert all three permutations to matrices :
8pMatA, pMatB, pMatAB< = Map@permToMat, 8permA, permB, permAB
0 1 : 0 0 0
0 0 0 0 1
0 0 1 0 0
1 0 0 0 0
0 0 0 , 1 0
0 0 1 0 0
0 1 0 0 0
0 0 0 1 0
0 0 0 0 1
1 0 0 , 0 0
0 0 1 0 0
0 0 0 0 1
1 0 0 0 0
0 0 0 1 0
0 1 0 > 0 0
Now pMatAB is known to be a permutation matrix because it was created from a permutation by permToMat. So carry out the test pMatA.pMatB == pMatAB 71
Symmetry Theory
True
This is only an example, not a proof. But there is nothing special about the permA and permB we chose, and in fact the relation is always true.
72
7. The fundamental theorem Preliminaries
7.1. Statement and commentary
The fundamental theorem of symmetry theory The symmetry transforms of an object form a group under the operation of sequential application. This Chapter puts together the definition of symmetry given in Chapter 4, and the definition of group given in Chapter 5. You might think the simplest way to prove this theorem would be just to go down the axioms and show that the symmetry transforms of an object fulfill each axiom. This almost works, but it runs into trouble at the Inverse Axiom. For instance, consider all the symmetry rotations of the cube; there are only twelve of them. As will be shown in detail in the next chapter, they can be constructed by closure from only two rotations, so the Closure Axiom is satisfied. There is a no-rotation element, so the Unit Axiom is satisfied. All matrix multiplications are associative, so the Associative Axiom is satisfied. But how can we be sure (without detailed examination, which we want to avoid in this general theorem) that within this little closed set, every element has an inverse? Strangely, no one has been able to create a simple, direct line of reasoning that assures it. Fortunately, a clever trick has been found that does the job without too much distraction. The trick begins by remembering that the twelve matrices in question are just twelve chosen from the universe of all unitary 3-by-3 matrices, a set which is known to form a group. Then there are two things to show: (1) Every member of the closed set is a symmetry transform of the object, and (2) The closed set inherits, from its infinite universe group, all the properties that make it a finite group. The trick makes this quite easy.
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_7, © Springer Science+Business Media, LLC 2009
73
Symmetry Theory
7.2. Proof of the fundamental theorem 7.2.1. The universe of transforms We will write this proof specifically for 3-by-3 matrix transforms. It could be made more general, but that would involve a lot of blather that does not really clarify the essentials. That is available already in plenty of math books. In Chapter 6 we showed that all unitary n-by-n matrices form a group under Dot. In particular, this applies to 3-by-3 matrices. This infinite group is the universe-group from which our symmetry transforms are chosen. In this proof, we will sometimes Dot the matrices into themselves, as in Chapter 6, and sometimes we will Dot them into an array of n point columns on their right, as in Chapter 4. Thus the application operator Ä is well defined for both kinds of operands.
7.2.2. The symmetric object Here we review, in more general language, some things that were shown by example in Chapter 4. A complex geometric object is represented by a set of points, which we symbolize as X p1 , p2 , ¼\. The pointed brackets enclosing the set mean that the contents are like a list, except that the order in which they are written is meaningless. When a transform T is applied to such an object, T Ä Xp1 , p2 , ¼\ means XT Ä p1 , T Ä p2 , ¼\.
Generally, T will change each point into another point, and the transformed set will be different from the original set. But it can happen that T either leaves a point unchanged, or else just changes it to another point already in the set. If no old points are lost, and no new ones created, the set is symmetric under T, according to our formal definition in 4.1 . Let sym = Xp1 , p2 , ¼\ be symmetric under two transforms, T1 Ä sym = sym
and T2 Ä sym = sym
Then the associative axiom requires
T1 Ä HT2 Ä symL = HT1 Ä T2 L Ä sym = sym
and we see that the product T1 Ä T2 is also a symmetry operator for sym. We give it a name like those of the other symmetry operators T3 = T1 Ä T2 . For a concrete example, click back to Chapter 4, “ New symmetries from old”. 74
Proof
and we see that the product T1 Ä T2 is also a symmetry operator for sym. We give it a name like those of the other symmetry operators T3 = T1 Ä T2 . For a concrete example, click back to Chapter 4, “ New symmetries from old”.
7.2.3. Construct a closed set of transforms The process described below is so useful that we will make a Mathematica operator MakeGroup that carries it out automatically. But first, we describe the process formally.
Say we start with a set of two symmetry transforms, XT1 , T2 \. We make no effort to include the unit element, or to make them mutually inverse. We then compute all pairwise products T1 Ä T1 , T1 Ä T2 , T2 Ä T1 , T2 Ä T2 . This might create nothing new, or it might create as many as four new transforms. We append everything new to the original set of two, creating XT1 , T2 , T3 , Ñ\. Then we make a new table of pairwise products, including products like T1 Ä T3 , which we did not have before. We again append any new products to the original set, and recycle. And so on, and on. We will see some groups where you have to start with more than just two transforms. But the closure process is entirely similar. We assume now that after a certain finite number of iterations, this process ceases to make new products; or in other words, we assume that the set closes. (This always happens if the object has a simple geometric symmetry. But since “simple” has been given no formal meaning, this statement is not part of the proof; it is just explanatory. But you know what we mean.)
7.2.4. Finite subgroup theorem
Theorem If G is a group, and H is a finite subset of G that is closed under multiplication, then H is a group. Comment: G may be finite or infinite, but as we work, think of it as the infinite group of all unitary 3-by-3 matrices under Dot. Lemma 1 Every element of H is the basis of a cyclic power sequence within H. Let A be any member of H, and consider the infinite sequence of powers of A. All members of the sequence must be in H, because H is closed under multiplication. Further, because H is finite, there must be among the powers of A a recurrent element B from which whole sequence repeats; otherwise the number of elements in H would be infinite. Suppose that B is Am+1 , and that it repeats with period n. (Lemma 2 will show that An+1 is E.) Then the sequence must read 75
Let A be any member of H, and consider the infinite sequence of powers of A. All members of the sequence must be in H, because H is closed under multipliSymmetry Theory
of elements in H would be infinite. Suppose that B is Am+1 , and that it repeats with period n. (Lemma 2 will show that An+1 is E.) Then the sequence must read A, A2 , Ñ , Am , B, B Ä A, Ñ , B Ä An , B, B Ä A, Ñ , B Ä An , B, Ñ
But B is Am+1 , so we can rewrite without using B at all :
A, A2 , Ñ, Am , Am+1 , Am+2 , Ñ , Am+n , Am+1 , Ñ , Am+n , Am+1 , Ñ
Note that after the power m+n, the power drops back to m+1. Now A was any element, not originally claimed as a recurring element. But looking at the first part of the sequence, we see that where Am+1 occurs, we can count back m places and we will be at A again. So in this sequence, every element is a recurring element with period m. (We originally said the period of B was n, but now we see that every element has the same period, so n = m.) So the sequence is really A, A2 , Ñ , Am , A, A2 , Ñ , Am , A, A2 , Ñ, Am , Ñ
So the set of the all powers of A that occur in its own power sequence is just a finite little set, P [A] = XA, A2 , Ñ , Am \. In other words, every element of H is the basis of a cyclic power sequence, which was to be proved. Lemma 2 The power sequence for every element A in H includes the identity. Since Am is followed by A, it must be true that Am Ä A = A and regrouping, also that A Ä Am = A. But by definition, only the unit element E behaves like Am in these equations, so Am = E. Lemma 3 The power sequence for every element A in H includes the inverse A -1 . Since E is preceded by Am-1 , we have Am-1 Ä A = E and regrouping, A Ä Am-1 = E. But the element that behaves like Am-1 is by definition A-1 , the inverse of A. Since we started by saying "Let A be any member of H Ñ", the inverse of every element in the sequence is also present somewhere in the sequence.
76
Proof
Proof of the theorem Nothing in Lemma 1 says that the power sequence based on A, P A], [ contains all the elements of H. Except in pure cyclic groups, it does not. So if C is an element of H not contained in P A [ ], we start again with C and construct its power sequence P C]. [ We continue to construct power sequences until all the elements of H appear in some power sequence. Then we combine all the power sequences, discarding duplicate elements. (In Mathematica, this is done by the Union operator.) The Union of all power sequences of H is the same as H itself, because: (a) The power sequences do not omit anything in H, because every element of H either occurred in a power sequence, or was used to start a new power sequence. (b) The power sequences cannot contain anything new, because we began by saying "let H be a finite subset Ñ closed under multiplication". Now we can successfully examine the group axioms, one by one. 1. Closure 2. Unit 3. Inverse 4. Associative
The set H is closed under multiplication by hypothesis. By Lemma 2, H includes the unit element. By Lemma 3, H includes an inverse partner for each element. The multiplication operator for H is the same as for G . Since G is a group, the operator is associative.
All four axiomatic requirements are met. Therefore, if H is closed under multiplication, then H is a group, as was to be shown.
7.2.5. Example of power sequences in a group The central claim of the proof is that all finite groups can be split up into nonoverlapping power sequences. Just to make this absolutely clear, we carry it out explicitly for a group named "D3h" , which is tabulated in the Symmetry` package. The standard names of its elements are allGroupNames = ElementNames@"D3h"D
8E, C3a, C3b, C2a, C2b, C2c, Σh, S3a, S3b, Σva, Σvb, Σvc<
We convert one of the names to the matrix itself :
matS3a = "S3a" . NamesToRepMats@"D3h"D
::-
1 2
,-
3 2
, 0>, :
3 2
,-
1 2
, 0>, 80, 0, -1<>
We use NestList (look it up) to construct the power sequences based on an element named "S3a" . Since the group has only 12 elements, we make a sequence of 12 elements. This has to be long enough. 77
Symmetry Theory
element named "S3a" . Since the group has only 12 elements, we make a sequence of 12 elements. This has to be long enough. P@S3aD = NestList@ð.matS3a &, matS3a, 12D . RepMatsToNames@"D3h"D
8S3a, C3b, Σh, C3a, S3b, E, S3a, C3b, Σh, C3a, S3b, E, S3a<
This power sequence has a repeat length of 6. We eliminate the repeats : UP@S3aD = P@S3aD Union 8C3a, C3b, E, S3a, S3b, Σh<
Which elements of group D3h do not appear in this sequence? Complement@allGroupNames, UP@S3aDD 8C2a, C2b, C2c, Σva, Σvb, Σvc<
Six elements did not appear. The next step is to make the power sequence based on the first such element : matC2a = "C2a" . NamesToRepMats@"D3h"D
881, 0, 0<, 80, -1, 0<, 80, 0, -1<<
P@C2aD = NestList@ð.matC2a &, matC2a, 12D . RepMatsToNames@"D3h"D
8C2a, E, C2a, E, C2a, E, C2a, E, C2a, E, C2a, E, C2a<
UP@C2aD = P@C2aD Union 8C2a, E<
The repeat length is only 2. This says that element C2a is its own inverse. This is true; C2a is a twofold rotation. The same is true for any element with a C2_ name. Similarly, all Σ_ names are reflections, and also give power sequences with only two members. Therefore, the whole group is the Union of the power sequences based on seven of its elements: S3a, C2a, C2b, C2c, Σva, Σvb, and Σvc. This is a very typical situation.
78
How this theorem helps
7.3. How this theorem helps Stephen Jay Gould, late lamented natural history essayist and Agassiz Professor of Biology at Harvard, told this story about his eponymous predecessor, Louis Agassiz. Prof. Agassiz assigned a new student to draw a fish pickled in formaldehyde. At the end of the day, Agassiz glanced at the drawings and said, "No! You have not seen one of the most essential features of this animal!". This went on for several days. The student's drawings became more and more detailed in fin and scale and marking, but Agassiz always rejected them, never explaining why. Finally, on the sixth day, fainting from formaldehyde fumes, the student saw it: His error was not in the details, but in the picture as a whole. The fish had bilateral reflection symmetry. We repeat this story to remind ourselves that humans are not necessarily very good at seeing symmetry transforms "instinctively". The fundamental theorem, however, gives us a way of finding the ones we fail to see. But wait, you may ask, absolutely all of them, without fail? Well, yes, but with one little reservation. We discuss the reservation later; first, we describe the basic procedure: To construct the group of an object, begin by examining the object. Put a well chosen Cartesian coordinate system on it, and write down all of its symmetry transforms that you can see, in the form of 3-by-3 Cartesian transform matrices. (You will see many examples of these matrices just ahead.) You will probably miss some of the object's symmetry transforms, but don't worry; this will not matter. When you have a list of as many symmetry matrices as you can see, make a multiplication table from them. Any new matrix that appears in the table is a symmetry matrix that you missed by direct observation. Look at the object again, and you will see it this time. Now join the new matrices onto the old list, and calculate the new, larger table. Continue this until you get a table with nothing new in it. At this point you will have a group of symmetry transforms that characterizes the object. Now comes the unanswerable question: Is this the set of ALL symmetry transforms of the given object? You can never be mathematically certain that it is, because it is possible that in your examination, you failed to notice a symmetry element that is there, but completely independent from the ones that you did see. If, at a later time, this new symmetry element comes to your attention, you may add it to your table and expand the table until it closes again. Your description of the symmetries of the object will be improved; but then of course, the question comes comes again: again: Do Do we we have have ALL ALL the the symmetries symmetries this this time? time? The The answer, answer, question alas, must must be be the the same. same. alas,
79
8. The multiplication table Preliminaries
8.1. The generalized “multiplication” table Consider a group with unspecified operator ⊗ and a list of n elements, named {E, A, B,..., Z}. The Closure Axiom says that a “ product” is defined for every ordered pair of these elements, giving n2 products in all. It seems natural to display them in a square “multiplication” table. We have written a display operator for such tables, called BoxUp. Here is what it produces if we take the elements to be {E, A, B,C}, and the entries to be blanks : blankMat = Table@"", 8i, 4<, 8j, 4
A
B
C
E A B C
We must decide once and for all whether the entries in such a table will be “row ⊗ column” or “column ⊗ row”. The nearly universal convention for naming the elements of matrices is {row,column}, so we pick the form closest to this; namely, row ⊗ column. Thus the simple matrix of table entries will be els = 8"E", "A", "B", "C"<; productMat = Table@elsPiT ⊗ elsPjT, 8i, 4<, 8j, 4
E⊗A A⊗A B⊗A C⊗A
E⊗B A⊗B B⊗B C⊗B
E⊗C A⊗C B⊗C C⊗C
To put row and column headings on it, use BoxUp , with a blank for the upper left element :
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_8, © Springer Science+Business Media, LLC 2009
81
Symmetry Theory
BoxUp@productMat, 8"E", "A", "B", "C"<, "", 1.1D E A B C
E E⊗E A⊗E B⊗E C⊗E
A E⊗A A⊗A B⊗A C⊗A
B E⊗B A⊗B B⊗B C⊗B
C E⊗C A⊗C B⊗C C⊗C
If the unit element E comes first in the element list, then the first row and firs column simplify by the Unit Axiom. Now we take the default “Left ⊗Right ” in the upper left to remind ourselves that the row label goes on the left of the ⊗ and the column label goes on the right, in operations of the form Left ⊗ Right (or in square bracket notation, op[Left,Right]). Here it is: simplMat = productMat ê. "E" ⊗ X_ -> X ê. X_ ⊗ "E" -> X; BoxUp@simplMat, 8E, A, B, C
E A B C
E
A
B
C
E A B C A A⊗A A⊗B A⊗C B B⊗A B⊗B B⊗C C C⊗A C⊗B C⊗C
The redundant row and column labels (top row and left column, above) are often omitted. The Closure Axiom says each product must evaluate as E, A, B, or C. But the other axioms put significant restrictions on how the table may fill out. The argument is simple and quick, and is given below.
82
Latin square
8.2. Latin square theorem 8.2.1. Statement We start with a definition : Latin square If, in a square table, every element appears exactly once in each column and once in each row, the table is a Latin square. This definition makes it easy to state the theorem : Latin square theorem If an operation and a list of elements form a non-redundant group, then the multiplication table of the group is a Latin square.
8.2.2. Proof First, we show that no element may appear twice in any row or column of this table. Consider the A row, and assume that some element X appears twice in this row. This means that there are two columns, headed by different elements U and V, in which A ⊗ U == A ⊗ V == X. But the Inverse Axiom says that A has an inverse called A-1 , and multiplying both members of the first equality by A-1 from the left, we have A-1 ⊗(A ⊗ U) == A-1 ⊗(A ⊗ V) The Associative Axiom allows us to rewrite this as ( A-1 ⊗ A)⊗ U == ( A-1 ⊗ A)⊗ V, and the Inverse Axiom then allows simplification to E ⊗ U == E ⊗ V The Unit Axiom then says U == V contradicting our assumption that the group is non-redundant. The assumption that some A appears twice in some row is therefore inconsistent with the axioms, and with the assumption of non-redundancy. The same argument, 83 applied to the transpose of the multiplication table, shows that no A can appear twice in any column. So the multiplication table must be a Latin square, which was to be proved.
Symmetry Theory
contradicting our assumption that the group is non-redundant. The assumption that some A appears twice in some row is therefore inconsistent with the axioms, and with the assumption of non-redundancy. The same argument, applied to the transpose of the multiplication table, shows that no A can appear twice in any column. So the multiplication table must be a Latin square, which was to be proved.
8.2.3. A corollary: the rearrangement theorem A corollary is a quick and easy theorem that follows from another theorem. It is often just an alternative statement of the theorem, or a little different way of looking at the result. The Latin Square theorem has the following corollary : Corollary : The Rearrangement Theorem If all the elements of a group are multiplied by some element of the group, then the result is a rearrangement of the group. Let the unit element come first in the first row of a group multiplication table, and take the first row as the standard order of the group. Every other row is just a left-multiplication of this row by some element of the group, and by the Latin Square theorem, each row is just a rearrangement of the same group, which was to be proved.
8.3. The Latin square converse: True or False? 8.3.1. Converses in general The converse of a theorem interchanges the premise (the If part) and the conclusion (the then part). Sometimes this makes a valid theorem and sometimes not. In the present case, the converse statement would be: Converse of the Latin square theorem : If the multiplication table of a list of elements is a Latin square, then the list of elements is a group. Is this converse True or False ? Keep this question in mind as we proceed. Remember, a single counterexample is enough to disprove a proposed theorem. If you just have to peek 84 ahead, click here.
Converse
Keep this question in mind as we proceed. Remember, a single counterexample is enough to disprove a proposed theorem. If you just have to peek ahead, click here.
8.3.2. Exploring an example Here is the multiplication table of a certain operator and a certain element list, disguised by being transformed into letter-names. We hide the calculation of the table to avoid giving the answer away too soon.
LtnSq =
A B C D
A C D A B
B D A B C
C A B C D
D B C D A
The multiplication table is a Latin square, as predicted for groups. So the Latin square theorem does not exclude the possibility that it is a group, but it does not prove it either. The converse of Theorem 1 says it is a group, but we do not know if the converse is true or false. We do not know what the elements are or what the operation is. To determine whether we have a group we must show, from the structure of the multiplication table alone, that each of the four axioms holds. We reason carefully, axiom by axiom, only on the basis of what we see in the multiplication table : 1. By inspection of the table, the Closure Axiom holds. 2. The third row and third column are identical to the original element list, as seen in the top and left headings. The label of this row and column is C; thus C is the unit element, and the Unit Axiom holds. 3. Every row and every column contain one unit element C, so every element has an inverse. Furthermore, wherever there is a C at position Pi,jT, it also appears at position Pj,iT. Therefore, the Inverse Axiom holds. 4. It remains now only to verify the Associative Axiom. Remember, we want to draw our conclusion solely from the content of the table. This cannot be done by a simple inspection; the Associative Axiom deals with triple products, whereas the table gives direct information only about double products. The only way to test the Associative Axiom is to use the table to form all possible triple products and test them for associativity. In a 4-by-4 table, there will be 43 = 64 cases. The test is easily automated, using the integer name trick. Instead of using the actual element names, we replace each element by an integer, 1 through 4. When we “multiply” these number-names we use the given multiplication table 85 itself to look up the value of the product. In the hidden calculation above we defined
Symmetry Theory
The test is easily automated, using the integer name trick. Instead of using the actual element names, we replace each element by an integer, 1 through 4. When we “multiply” these number-names we use the given multiplication table itself to look up the value of the product. In the hidden calculation above we defined LtnSq
88C, D, A, B<, 8D, A, B, C<, 8A, B, C, D<, 8B, C, D, A<<
Check by inspection that this is the content of the boxed table above. We begin by translating LtnSq into number-names: LtnSq
88C, D, A, B<, 8D, A, B, C<, 8A, B, C, D<, 8B, C, D, A<<
LtnSqN = LtnSq ê. 8"A" Ø 1, "B" Ø 2, "C" Ø 3, "D" Ø 4<; MatrixForm@LtnSqD Ø MatrixForm@LtnSqND C D A B
D A B C
A B C D
B C D A
Ø
3 4 1 2
4 1 2 3
1 2 3 4
2 3 4 1
Now on the right, the product 1 ⊗ 1 is 3, for instance. (This is OK; they are names, not integers.) In this way of naming things, the value of product i ⊗ j is given by the content of the table at position i,j. This makes it easy to construct an exhaustive association test. We simply write the association test for the triple product i ⊗ j ⊗ k ( namely, i ⊗(j ⊗ k)==(i ⊗ j)⊗ k ) and then run i, j, and k over all possible values. Remember, the ⊗ is carried out by table look-up. Each test yields either True or False. The numerical Latin square on the right above is called LtnSqN, The exhaustive test is
Table@LtnSqNPi, LtnSqNPj, kT T == LtnSqNP LtnSqNPi, jT, kT, 8i, 4<, 8j, 4<, 8k, 4
To see the full output, take away the Union operator and rerun. If even one case had produced a False, the return from Union would have reported {True,False}. But it did not, so the Associative Axiom holds. Since all four axioms have been verified, we have a group, as determined solely by the properties of the group multiplication table. If you are curious, the operator was Times and the element list was {-1,Â,1,-Â}. We violated the usual convention of writing the unit element first, just to show that it can still be identified by its fundamental properties. 86
8.3.3. A different Latin Square to test
Converse
8.3.3. A different Latin Square to test Below you see the multiplication table for an operator and an element list that do NOT form a group. What's wrong, why not? Just repeat all the tests made above, and you will see. LtnSq2 = 88C, B, A, D<, 8D, C, B, A<, 8A, D, C, B<, 8B, A, D, C<<; GridForm@LtnSq2D C D A B
B C D A
A B C D
D A B C
After you verify that this Latin square is not the multiplication table of a group, you will have a counter-example which proves that the converse of the Latin Square theorem is false. If for some reason you can't get it to work, click here.
8.4. Automated multiplication tables 8.4.1. Demonstration of MultiplicationTable There is a MultiplicationTable operator that comes with the SymmeÖ try` package of this book, loaded automatically during the preliminaries of each chapter. If you give it the group “multiplication” operator, a list of the group elements in concrete form, and a list of names for the group elements, it will carry out each possible multiplication, replace each product by its name, and display the result as a square table. Since it is a package operator, you may call up a thumbnail description of it. Do so. We give the group of four numbers a name : groupN4 = 81, Â, -1, -Â<;
Make its MultiplicationTable , using Times as the group operator:
87
Symmetry Theory
tableN4 = MultiplicationTable@ Times, groupN4, 8"E", "A", "B", "C"
A B C E
B C E A
C E A B
Section 8.5, below, shows in detail how this operator works. But first, in 8.4.2 just below, we continue this example to illustrate a basic issue of group theory.
8.4.2. Abstract groups and representations of groups Here is a four-element group of matrices that perform rotations about z by 0 turn, 1/4 turn, 2/4 turn and 3/4 turn, respectively: groupC4 = 8 881, 0, 0<, 80, 1, 0<, 80, 0, 1<<, 880, -1, 0<, 81, 0, 0<, 80, 0, 1<<, 88-1, 0, 0<, 80, -1, 0<, 80, 0, 1<<, 880, 1, 0<, 8-1, 0, 0<, 80, 0, 1<<<;
Make its MultiplicationTable , using Dot as the group operator : tableC4 = MultiplicationTable@ Dot, groupC4 , 8"E", "A", "B", "C"
A B C E
B C E A
C E A B
tableC4 == tableN4 True
It is the same multiplication table again! Now we will produce it again with yet another group: Here are the cyclic permutations of {1,2,3,4} :
groupP4 = 881, 2, 3, 4<, 82, 3, 4, 1<, 83, 4, 1, 2<, 84, 1, 2, 3<<;
Make its MultiplicationTable, using Permute as the operator : tableP4 = MultiplicationTable@
88
D;
Automation
Permute, groupP4 , 8"E", "A", "B", "C"
A B C E
B C E A
C E A B
Review what we have done : tableN4 == tableC4 == tableP4 True
The multiplication tables are exactly the same. These groups have a deep relationship, and we need words that express the similarity as well as the differences. Here they are: An abstract group is defined completely by its symbolic multiplication table. A group of concrete mathematical objects (matrices, permutations, etc.) that obeys that table (and does not obey any smaller table) is a faithful representation of the abstract group. How would you express the deep relationship in words, in the example above? These are all cyclic groups of four; it's just the cycling object that is different. In the first example, the cycling object is the number  ; the group is given in order by 9Â0 , Â1 , Â2 , Â3 =; then Â4 takes you back to Â0 . In the second example the cycling object is the matrix
C4 = 880, -1, 0<, 81, 0, 0<, 80, 0, 1<<;
taken to MatrixPowers 0 through 3. Matrix power 4 brings you back to power 0, the unit matrix. MatrixPower@C4 , 4D
881, 0, 0<, 80, 1, 0<, 80, 0, 1<<
In the third example the cycling object is the list {1,2,3,4}, rotated left by one place, zero through three times. The fourth leftward rotation then returns you to the original. RotateLeft@81, 2, 3, 4
89
Symmetry Theory
On your own (a) Dot matrix C4 with itself 1 time, 2 times, 3 times, and 4 times . (b) Apply RotateLeft similarly to the list {1,2,3,4}. If abstract groups had systematic names, we would have to call this one something like FourCycle. We would then say that groupN4, groupC4, and groupP4 are faithful representations of the abstract group FourCycle. In the next few chapters, we will continue to work primarily with 3×3 Cartesian transform matrices. Just keep in mind that they are only one kind of representation of the underlying abstract groups . Far ahead in Chapter 25 we will learn an algorithm for constructing matrix representations that imitate the symmetries of any set of symmetric objects. Click to it now for a preview of the powerful ideas that lie ahead. Don't worry if you do not understand it completely right now. This book builds up systematically, and when you get to Chapter 25 you will understand it.
8.5. How MultiplicationTable works 8.5.1. The basic core operator, Outer In this Section we show in detail how the MultiplicationTable operator was constructed, and people who are willing to take it on faith can skip on to the next chapter. However, there are some interesting non-obvious issues that arise, and to those at all interested in symbolic computation itself, this section should be worth reading. Mathematica has a core operator that constructs exactly the kind of multiplication table implied by Axiom1. It is the Outer operator, which constructs every possible pairwise product from any two given lists, using any desired operator. As an initial exhibit of its powers, we use the undefined symbolic operator CircleTimes: Outer@CircleTimes, 8a, b<, 8a, b
a⊗b b⊗b
Here is a concrete numerical example where it works well:
Outer@Times, 81, Â<, 81, Â
90
How it works
 -1
1 Â
8.5.2. A problem with matrices, and its solution Our main concern will be groups of matrices, and a problem arises when we try to make a multiplication table for matrices using this method. We take two matrices that are easy to multiply together mentally aMat = K
0 O; 1 0 O; 3
1 0 3 bMat = K 0
Now we attempt to calculate a multiplication table for the list {aMat,bMat} : Outer@Dot, 8aMat, bMat<, 8aMat, bMat
1.0<, 0.0<, 0.0<, 1.0<, 3.0<, 0.0<, 0.0<, 3.0<,
81.0, 80.0, 80.0, 81.0, 83.0, 80.0, 80.0, 83.0,
1.1<<, 0.1<<, 0.1<<, 1.1<<, 3.1<<, 0.1<<, 0.1<<, 3.1<<,
881.3, 880.3, 880.3, 881.3, 883.3, 880.3, 880.3, 883.3,
1.0<, 0.0<, 0.0<, 1.0<, 3.0<, 0.0<, 0.0<, 3.0<,
81.0, 80.0, 80.0, 81.0, 83.0, 80.0, 80.0, 83.0,
1.3<<<, 0.3<<<<, 0.3<<<, 1.3<<<<<, 3.3<<<, 0.3<<<<, 0.3<<<, 3.3<<<<<<
How bizarre and ugly! The Outer operator failed because Dot acted at too low a level, trying to Dot integers with integers instead of matrices with matrices. There is a very simple way to get what we want: just append a trailing 1 to the list of parameters that we feed to Outer. This tells the Dot operator to act at “level 1” of the given lists. In {aMat,bMat}, the matrices are at “ level 1”, the matrix rows are at “ level 2”, and the elements themselves are at “ level 3”. If you omit the level instruction, the operator acts by default at the lowest level. In this case, it tries to Dot integers with integers, yielding a mess. Now we redo it with Dot acting at the correct level, level 1 : matTable = Outer@Dot, 8aMat, bMat<, 8aMat, bMat<, 1D; % êê MatrixForm K
1 0 3 K 0
0 3 O K 1 0 0 9 O K 3 0
0 O 3 0 O 9
This is the desired answer. What a difference that trailing 1 makes! 91
Symmetry Theory
This is the desired answer. What a difference that trailing 1 makes!
8.5.3. Symbolic output The output above, a matrix of matrices, suggests another issue. In a group table, each element is a member of the original list, and it has a name given in the name list. So we ought to be able to write the final output in terms of names again. This will be a great advantage when doing groups of large matrices, or other objects that are hard to identify at a glance. elements = :K
1 0 -1 0 O, K O>; 0 1 0 -1
names = 8"E", "M"<;
We make a recognition Rule: matRule = Thread@elements Ø namesD
8881, 0<, 80, 1<< Ø E, 88-1, 0<, 80, -1<< Ø M<
Make the table, and use the rule :
Outer@Dot, elements, elements, 1D ê. matRule êê GridForm E M
M E
Now you can see it at a glance. On your own Consider
E M
M E
. Is this the multiplication table of a group?
Give an iron-clad answer, based on a theorem you have seen.
8.5.4. The precision problem It is easy to identify and replace objects made of symbols or exact integers or other exact quantities. It is a little more difficult to identify objects that contain roundoff error, because two versions of an object that differ insignificantly in the final digit may not be identified as the same. Here are two numbers that differ in the only fourteenth digit:
92
How it works
a = 0.12345678901234; b = 0.12345678901237; 8a, b< 80.123457, 0.123457<
Does that 14th digit make any difference to Equal? a == b False
Mathematica never lies. Often two different routes to the same answer may yield differences in the 15th digit, and this can be a problem. But once recognized, it can be handled. The SetPrecision operator effectively rounds a real number at a given number of decimal digits. We round the numbers a and b above to 12 digits, and ask again if they are “equal” : a12 = SetPrecision@a, 12D; b12 = SetPrecision@b, 12D; 8a12, b12<
80.123456789012, 0.123456789012<
a12 == b12 True
The only remaining problem is the roundoff zero problem. Even when pared back to 12 significant digits, small numbers are not identified as a true zero. tiny = SetPrecisionA0.1234567890123456 * 10-23 , 12E 1.23456789012 µ 10-24
tiny == 0 False
The Chop operator does what we want:
ChopA91. * 10-9 , 1. * 10-10 , 1. * 10-11 , 1. * 10-12 =E 91. µ 10-9 , 1. µ 10-10 , 0, 0=
The results above may differ a little bit on different computers, but the output should be a list that contains some small numbers and some zeroes where even smaller numbers have been set to an exact zero. Using Chop when we test tiny, it is now identified as effectively zero: Chop@tinyD == 0 True
Therefore, we set up MultiplicationTable so that it will truncate all 93 numbers to prc significant figures and Chop all very small numbers to an exact zero, before trying to make identifications. The significant figures parameter prc is by default 12, but it can take other values.
Symmetry Theory
Therefore, we set up MultiplicationTable so that it will truncate all numbers to prc significant figures and Chop all very small numbers to an exact zero, before trying to make identifications. The significant figures parameter prc is by default 12, but it can take other values. On your own Pull down the syntax statement for MultiplicationTable and read it carefully.
8.5.5. What to do with unidentifiable products What happens when recognition fails? the following table :
Suppose we apply our old matRule to
badTable = 88881, 0<, 80, 1<<, 88-1, 0<, 80, -1<<<, 888-1, 0<, 80, -1<<, 882, 0<, 80, 2<<<<; % êê GridForm 881, 0<, 80, 1<< 88-1, 0<, 80, -1<<
Note that badTable contains
88-1, 0<, 80, -1<< 882, 0<, 80, 2<<
2 0 0 2
, which will not be recognized.
badTable2 = badTable ê. matRule; % êê GridForm E M
M 882, 0<, 80, 2<<
When recognition fails, the table will be neater if it reports "?" instead of the literal unrecognized matrix. useQM@x_D := If@MemberQ@names, xD, x, "?", "?"D; Map@useQM, badTable2, 82
94
M ?
Tests
8.6. Test MultiplicationTable We will test MultiplicationTable using calls to the package operator CartRep[gpNm]. This is short for CartesianRepresentation, and gpNm is the string name of any group in the GroupCatalog. This operator goes into the package and returns the Cartesian transformation matrices that we have been calling “ the group”. But technically speaking an abstract group is defined by its multiplication table. The CartRep is a list of 3×3 Cartesian transform matrices that obey the same table as the abstract group. The package Symmetry` contains a number of predefined matrix groups. We used "C3v" above; now we test the package operator using another one called "D2h". matsD2h = CartRep@"D2h"D; % êê GridList :
1 0 0
0 1 0
1 0 0
0 -1 0
1 0 0
0 1 0
0 0 1 0 0 -1 0 0 -1
-1 0 0
,
-1 0 0
,
,
0 -1 0
1 0 0
0 0 1
0 -1 0 0 -1 0
,
0 0 -1 0 0 1
,
-1 0 0
0 1 0
0 0 -1
0 1 0
0 0 1
,
,
-1 0 0
>
There are also predefined element names : namesD2h = ElementNames@"D2h"D; % êê FullForm List@"E", "C2z", "C2x", "C2y", "inv", "sz", "sy", "sx"D
All the names are strings. We ask for the group multiplication table (under the operator for matrix multiplication, which is Dot) :
95
Symmetry Theory
mtD2h = MultiplicationTable@Dot, matsD2h, namesD2hD; % êê GridForm E C2z C2x C2y inv sz sy sx
C2z E C2y C2x sz inv sx sy
C2x C2y E C2z sy sx inv sz
C2y C2x C2z E sx sy sz inv
inv sz sy sx E C2z C2x C2y
sz inv sx sy C2z E C2y C2x
sy sx inv sz C2x C2y E C2z
sx sy sz inv C2y C2x C2z E
On your own There is a short form of this operator that works on tabulated groups : MultiplicationTable["D2h"] Try it. So far, so good. Now we try it on a non-group, the list {1,Â}under Times. 1  Numerically the multiplication table will be K O. If we name 1 as A and  -1  as B, we should get a question mark in the lower right, since Â* will not be recognized. MultiplicationTable@Times, 81, Â<, 8A, B
B ?
Have we found all the bugs in the MultiplicationTable routine? You can never say yes to this question. In the interest of full disclosure, open UrSymmetryV6.nb and Find the exact text of the operator. For a cautionary tale on program bugs, click here.
8.7. Redundant groups Redundant groups will arise naturally when we get into representation theory, but here we make a simple redundant group by simply joining together two copies of a non-redundant group. We take a small one, C3 : redundantGroup = ; 96
Redundant groups
Join@CartRep@"C3"D, CartRep@"C3"DD; % êê MatrixList êê Size@5D 1 0 0 : 0 1 0 , 0 0 1
-
1
3
-
2 3
2 -
1
2 0
2 0
-
0 , -
0 1
1
3
2
2
3
-
1
2 0
2 0
0 , 0
1 0 0 0 1 0 , 0 0 1
-
1 2 3
2 0
1
3
-
2 -
1
2 0
-
0 , 0 1
-
1
3
2
2
3 2 0
-
1
2 0
0
>
0 1
We name the matrices E, A, B, U, V, and W, respectively: MultiplicationTable@Dot, redundantGroup, 8"E", "A", "B", "U", "V", "W"
A B E A B E
B E A B E A
E A B E A B
A B E A B E
B E A B E A
The names U,V, and W do not appear at all; other names appear multiple times in each row and column. That is because the name replacement rule is used as soon as the first match is seen. Matrices A and V are identical, and the A rule is always tried and used before V rule. Thus redundant groups really look redundant and can be identified at a glance from their multiplication tables.
8.8. End Notes 8.8.1. Not a group table The following is a Latin Square, but is it the multiplication table of a group? Clear@LtnSq2, A, BD;
LtnSq2 =
C D A B
B C D A
A B C D
D A B C
P1T
88C, B, A, D<, 8D, C, B, A<, 8A, D, C, B<, 8B, A, D, C<< Note: Part 1 of the GridForm of a matrix is the matrix itself, as you see above.
Test whether the multiplication operation is associative :
LtnSq2N = LtnSq2 ê. 8A Ø 1, B Ø 2, C Ø 3, D Ø 4<; MatrixForm@LtnSq2D Ø MatrixForm@LtnSq2ND 97
Symmetry Theory
C D A B
B C D A
A B C D
D A B C
Ø
3 4 1 2
2 3 4 1
1 2 3 4
4 1 2 3
Table@LtnSq2NPi, LtnSq2NPj, kT T == LtnSq2NP LtnSq2NPi, jT, kT, 8i, 4<, 8j, 4<, 8k, 4
There was at least one False among the 64 cases, so the operator is not associative. (Take away the Flatten and Union operators to see all 64 cases.) Therefore it is not a group table, in spite of being a Latin Square. This one counter-example proves that the converse of the Latin Square theorem is false.
8.8.2. The great aerial warfare program The Israeli Air Force wrote an immense aerial warfare program that used comprehensive radar coverage of the Middle East to keep track of everything flying. This information was fed to an artificial intelligence routine that told Israeli fighter planes how to attack, or how to evade. It was used in the 1982 air war in the Bekaa Valley, and it gave Israel a decisive advantage. In fact, the Israelis shot down about 100 Syrian MiGs without losing a single fighter of their own. (Click to the Wikipedia) So you have to say this was very successful software, tested repeatedly in the very fire of battle. After the war, an Israeli plane crossed the equator under the control of this program. Immediately, the plane flipped upside down, and the pilot had scramble to save himself. The bug was traced to the function Tan[q], which has a singularity at p/2, the latitude of the equator : Tan@qD
pê2
p
The Bekaa Valley is well north of the equator, and the program never had to deal with negative values of Tan[q]before. This can happen whenever an algorithm is taken into new territory. I hate to think what may happen with some of mine ...
98
9. Molecules Preliminaries
9.1 Molecule definitions in Mathematica Our Mathematica molecules are written and maintained by a simple form of object-oriented programming, which insures that errors are caught at the time of molecule entry, rather than during their use. One of the predefined molecules in the Molecules` package is “methane". Look at the data contained in it : MoleculeToList["methane"] // GridForm H H H H C
: 10 000 , 6287
6287 6287 , 10 000 > 10 000
:- 10 000 , - 10 000 , 6287
:-
6287
6287 6287 , 10 000 , 10 000
-
6287 , 10 000
-
: 6287 , 10 000
-
80, 0, 0<
6287 > 10 000 6287 > 10 000 6287 > 10 000
81, Td< 82< 83< 84< 81<
On your own Also look at this without the GridForm display wrapper. Each row of this matrix (i.e., each sublist of this list) contains the data for one atom, in the form of an "atom list". Each atom list contains three items : (1) The element symbol for the atom (2) The Cartesian coordinates for the atom, in Angstrom units I1 Å = 10-10 MeterM Although they are experimental values good (at most) to 4 or 5 sig figs, they are written above as infinite precision numbers (e.g., 0.6287 6287 Å ® 10 ) . As you will see below, this allows us make the symmetry exact 000 even when the known bond distances are only approximate. (3) A list of tags that distinguish it from other atoms of the same kind. The tag list of each atom must be a List of Strings, and it must contain at least one item. The first item in the tag list is displayed in the center of the atom by graphics operators. If you want no tag, put a null string ( "" ) in first position. But you cannot leave it blank. (4) Every molecule has an extra element in the tag list of its first atom; namely, be the last item W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, 99 DOI 10.1007/b13137_9, © Springer Science+Business Media, LLC 2009
Symmetry Theory
(4) Every molecule has an extra element in the tag list of its first atom; namely, the point group to which the molecule belongs. It must always be the last item in the first tag list. In this position it will not interfere with any programming that makes use of the preceding tags. If you do not know the group, enter "?" as the group tag. Now we look at the first atom of the molecule in FullForm :
MoleculeToList@"methane"DP1T FullForm
List@"H", List@Rational@6287, 10 000D, Rational@6287, 10 000D, Rational@6287, 10 000DD, List@"1", "Td"DD
Now you can see that the names of the elements and the tags are all Strings so that they cannot be confused with algebraic or symbolic quantities. When writing a new molecule data list from scratch, remember that the quotes are required. Note also that quotes are required around the names of molecules. What sort of thing, besides an atom number, might go into the tag list of an atom? In a protein, each amino acid could carry a common tag on all its atoms. This tag would make it possible for a special display operator to color, say, all the lysines green. Another tag could record a calculated local electrical potential at the atom, or the atom's magnetic shielding constant. It is up to the user to define the tag list, and to keep track of its meaning. You can bring out a list of all the tags with AtomTagList@"methane"D
881, Td<, 82<, 83<, 84<, 81<<
Note that group Td is the last tag of the first atom.The first tags, used by Atom Graphics, are brought out by FirstTagList@"methane"D 81, 2, 3, 4, 1<
The list of elements can also be called up: ElementList@"methane"D 8H, H, H, H, C<
AtomNameList@"methane"D
The atom number subscripts are in a distinctive type face ("Copperplate") to diminish confusion between, e.g., the second H atom and the molecule H2 .
100
Molecules
On your own Enter MoleculeCatalog to see the names of all molecules currently defined. Look at the data lists of a few of them.
9.2 Molecule "objects" To construct a molecule, begin by assembling a list of data for it, in the format given above. Say you give it the name molList. However, none of our molecule operators can work on molList as it stands. To make it useful you must call the object-making operator ListToMolecule[molList,"molName"] which checks the format of your molList, and then (and only if the format is correct) sets it equal to molecule["molName"]. It has fairly explicit error messages, designed to help you get you molecules correct. Here is a molecule list with a typo in it : badMethaneList = : :"H", :
>, 8"1", "Td"<>, 10 000 10 000 10 000 6287 6287 6287 :"H", :,, >, 8"2"<>, 10 000 10 000 10 000 6287 6287 6287 :"H", :, ,>, 8"3"<>, 10 000 10 000 10 000 6287 6287 6287 : H, : ,,>, 8"4"<>, 10 000 10 000 10 000 6287
6287
,
6287
,
8"C", 80, 0, 0<, 8"1"<<>;
ListToMolecule@badMethaneList, "badMethane"D non-String element name
Yes, one H is not a string (did not have quotes around it). This “object oriented” format check keeps our molecule formats correct. All molecule objects are stored together in a place not directly accessible to you. The only way to put them there is to use the ListToMolecule operator. If you need to see the list again, you must go through the molecule reading operator MoleculeToList["molName"] 101
Yes, one H is not a string (did not have quotes around it). This “object oriented” format check Symmetry Theorykeeps our molecule formats correct. All molecule objects are
list again, you must go through the molecule reading operator MoleculeToList["molName"] For example, the ammonia molecule is in the computer somewhere as an object having molecule as its Head, but you do not have direct access to it. Try to call it up: molecule@"ammonia"D molecule@ammoniaD
It returns unevaluated. This is just a slight protection to remind you that the format of the ammonia molecule has been checked and certified to be correct, and you should not mess around with it. This slight protection is easy to defeat, but the best advice is, don't try. The molecule objects are guaranteed to have the correct format, and any direct meddling might introduce an error. On your own Look at ammonia using MoleculeToList["ammonia"].
9.3 Molecule object operators We have a number of operators that work on molecule objects. Here is one that goes into the current molecule object collection, and pulls out all the molecule names : originalMC = MoleculeCatalog
81,3,5-trichlorobenzene, ammonia, benzene, brick, C2H2Br2Cl2 staggered, carbonate anion, CopperIIhexanitriteAnion4, cyclobutadiene, cyclopropenyl, cyclopropenylCation, eclipsedEthane, equilateral ozone, ethylene, formaldehyde, haloTet, hexachlorobenzene, icosahedron, methane, methaneOLD, naphthaleneCatoms, octaComplex, PCl5, PtCl4dianion, RNAdimer, staggeredEthane, terrylene, transHB3H2D2, twoTriangles, UF9, water, XeF4<
If you define new molecules, they will appear in the catalog after they are put away by ListToMolecule. A few more simple operators : MolecularWeight@"ammonia"D 17.0305
CenterOfMass@"methane"D 102
Molecule operators 90. ´ 10-7 , 0. ´ 10-7 , 0. ´ 10-7 =
EnclosingRadius@"ammonia"D 1.00167
Use the ? to see the precise definition of EnclosingRadius. The next one may be a little less familiar, InertiaTensor@"ammonia"D
991.57756, 0. ´ 10-7 , 0. ´ 10-7 =,
90. ´ 10-7 , 1.57756, 0. ´ 10-7 =, 90. ´ 10-7 , 0. ´ 10-7 , 2.94929==
This is used to find the symmetry axes of molecules that are entered in an asymmetric orientation.
9.4 How to make a molecule
From NIST to Mathematica
You may write a new molecule from scratch. Note, for instance that there is no “chloroform” molecule in the MoleculeCatalog. Here is how to add it: 1. Click on http://webbook.nist.gov/chemistry . 2. Under SearchOptions, you want Name. Click on it. 3. Type in chloroform. This will take you to the data on chloroform. 4. Click on “Computational Chemistry Comparison and Benchmark Database”. 5. Click on the blue underlined x at the intersection of the Experiment column and the Internal Coordinates row. 6. Scroll down to Geometric Data, and find the table. 7. Copy the content of the Cartesians table and Paste directly into a Mathematica notebook. The data will appear as an unpunctuated Input cell. Do a Format @ ClearFormatting on it and provide it with whatever it needs to become a Mathematica molecule list : chloroformList = 8 8"C", 80.0000, 0.0000, 0.5231<, 8"1", "C3v"<<, 8"H", 80.0000, 0.0000, 1.5961<, 8"1"<<, 8"Cl", 81.6562, 0.0000, -0.0928<, 8"1"<<, 8"Cl", 8-0.8281, 1.4343, -0.0928<, 8"2"<<, 8"Cl", 8-0.8281, -1.4343, -0.0928<, 8"3"<<<;
Above, the Cl atoms nearly, but not exactly, a third of a turn apart. If this is a problem, click to an End Note to see how to make the rotational symmetry exact. Make it into a molecule object : 103
Symmetry Theory
ListToMolecule@chloroformList, "chloroform"D Has chloroform has been added to the catalog ? We pull down the current catalog and use Complement to compare to the old catalog, pulled down and named above. Is there anything new : newMC = MoleculeCatalog; Complement@newMC, originalMCD 8chloroform<
There is. We will use it below to demonstrate the AtomGraphics operator.
9.5 Molecule graphics 9.5.1. AtomGraphics and BondGraphics The Molecules` package defines several operators for making molecules into graphics objects. The wo basic ones are AtomGraphics and Bond Graphics. If you want to see the atoms of the molecule “chloroform” (created above, in Section 9.4 ), the command is Options@AtomGraphicsD Column AxisLength ® Automatic AtomDiameterFactor ® 1 AtomLabels ® True ViewPoint ® 8-3, -24, 20< BaseStyle ® Text Boxed ® False ImageSize ® 8250, 250< Lighting ® Neutral
AtomGraphics@"chloroform", ImageSize ® 150, ViewPoint ® 83, -24, 10
104
Molecule graphics
Each element has its own color code. Above, C is gray, Cl is green, and H is white. Below, the default colors for the common elements :
H D
B
C Cu N O Cl Br
I
S
P Na K Xe F
U
Usually chemists want to see the bonds as well as atoms. For this we use BondGraphics: CHCl3pic = Show[{ BondGraphics["chloroform"], AtomGraphics["chloroform"]}, ImageSize ® 150, ViewPoint ® {3, -24, 10}]
105
Symmetry Theory
On your own Grab this image with the mouse and turn it to a new orientation. Show the bonds all by themselves with no atoms. Show the molecule with Cl-Cl bonds as well as C-Cl bonds. There is nothing in the molecule object that says which atoms are bonded to which. Instead, we draw bonds based strictly on inter-atom distances; by default, a bond will be drawn between any two atoms closer than 1.8 Þ. But if the default does not do what you want, look at the DistanceMatrix of the molecule : DistanceMatrix@"chloroform"D GridForm
From this you can find a bond length parameter of BondGraphics that will draw the bonds you want. As you see, 1.8 Þ is a good guess for chloroform: C-H and C-Cl bonds were drawn, but no others. 1.8 is nearly always a good first guess. No single 3D projection, even if perfectly drawn, can convey all the three dimensional information about a molecule. Orientational mouse drags will tell the full story for interactive readers, but for documents we need another strategy. Below in Section 9.6 and Section 9.7 you will see two quite different ways of presenting static multiple views that do convey all the three dimensional information.
9.5.2. The default molecule When you are working a lot with one particular molecule, it is nice to set it up as a default so you don't have to keep retyping its name so much. Taking a new example, we set $DefaultMolecule = "haloTet"; 106
Molecule graphics
$DefaultMolecule = "haloTet"; Now every operator that uses a molecule name will use this one by default. But note that you cannot use defaults and options together in the same operator. If you want display options, you have to use the Show wrapper, and make the display options into options of Show : Show@8BondGraphics@D, AtomGraphics@D<, ImageSize ® 150, ViewPoint ® 83, -24, 10
This is “haloTet”. It is like methane, but with four different halogens instead of hydrogens. It is a particularly simple handed molecule. On your own A bond is drawn by default between every pair of atoms closer than 1.8 Þ . Of course, this is not always appropriate. Take a look at the DistanceMatrix for this molecule to see that it is appropriate in this case. To practice using explicit bonding distances in BondGraphics, change the default molecule to "ethylene", and show a picture of it with C-C bonds and C-H bonds, but no H-H bonds. Then just for fun, add H-H "bonds" to the picture. Chemists, forebear. This is just a mathematical exercise.
107
Symmetry Theory
9.5.3. Options for AtomGraphics We want to make the “haloTet” picture easier to read. Redraw it without coordinate axes, with bigger atoms, and with better-looking atom labels. Call it ag: T8I = 8FontFamily ® "Times", 10, FontSlant ® "Italic"<; ag = AtomGraphics@"haloTet", H*Option1*L AxisLength ® 0, H*Option2*L AtomDiameterFactor ® 2, H*Graphics options*L BaseStyle ® T8I, ImageSize ® 100, ViewPoint ® 83, -24, 10
Now it is easy to put the bonds with the atoms : bg = BondGraphics@D; haloTetObj3D = Show@8ag, bg<, ImageSize ® 100D
108
StereoView
9.6 StereoView Let's look at a stereo graphic of haloTet. The left figure is for the left eye; the right, for the right. Can you make the image pop up in 3D? svhT = StereoView@haloTetObj3D, ImageSize ® 200D
Nearly everyone can see these figures in 3D with a little practice. If you have trouble, click once in the middle of the figure and drag the corner handles make the image smaller. Relax and let your eyes wander into double vision. Don't get scared; it is OK to see double. This may be the hardest part. Just think faroff thoughts, and try to enjoy seeing four figures floating and wandering. Tilt your head left or right until all four C atoms are at the same height. Hold there, and gradually let the middle two float together. They will fuse suddenly into a single 3D image, flanked by two rather unfocused peripheral images which you just ignore. You will feel completely relaxed and unstrained when you achieve this. You will see clearly that Cl, C, F defines one plane and I, C, Br defines a perpendicular plane. If you are nearsighted, it may help to take off your glasses and lean forward. Also, the pairs look much better when printed than they do on your computer screen. Print the image pair above, and try it with the hard copy. Programming the stereo pair in Mathematica was very easy, doing a little calculation to get a slightly different ViewPoint for each eye, and then using the GraphicsRow command to place the two pictures side by side. Open up the Molecules` package and see how it was done, if you like.
109
Symmetry Theory
9.7 AxialViews (a 3D shop drawing) No single view of a three-dimensional object can tell everything about it, no matter how well-drawn it may be. If the single views provided by AtomGraph ics are ambiguous, try AxialViews, which gives three views down the three coordinate axes: AxialViews[obj3D(,opts)] returns three panels arranged in a way that is standard for machine shop drawings. Its main input must be something that is already a Graphics3D object, so we use the chloroform molecule that we evaluated above : AxialViews@CHCl3pic, ImageSize ® 220D
On the upper right you see a “top” view, on the upper left is a “side” view, and on the lower right a “front” view. If you cut this figure out and folded down the front and side views, you would have three sides of a cube containing the object, with its projection drawn on each of the three faces. Theoretically, the object is described completely in these drawings. With a little practice and a little thought, you can grasp its structure so completely that you could make the object in a machine shop. On the compute screen, you can grab and rotate any of the three axial views using the mouse. But this ruins it, or course, for pasting into a document.
110
9.8 End Notes
End Notes
9.8 End Notes 9.8.1. Infinite precision coordinates The coordinates of the chloroform molecule, as pulled down from NIST, were good to the fourth decimal: chloroformList = 8 8"C", 80.0000, 0.0000, 0.5231<, 8"1", "C3v"<<, 8"H", 80.0000, 0.0000, 1.5961<, 8"1"<<, 8"Cl", 81.6562, 0.0000, -0.0928<, 8"1"<<, 8"Cl", 8-0.8281, 1.4343, -0.0928<, 8"2"<<, 8"Cl", 8-0.8281, -1.4343, -0.0928<, 8"3"<<<;
But its symmetry is not exact. We show here how to make it exact. The first step is to turn all decimal numbers into ratios of exact integers. This is done by the core Rationalize operator, with optional second parameter 0 : chloroformList2 = Map@Rationalize@ð, 0D &, chloroformListD Column :C, :0, 0, :H, :0, 0,
5231 >, 10 000 15 961 >, 10 000
:Cl, : 8281 , 0, :Cl, :-
5000
81, C3v<> 81<>
58 >, 625
8281 14 343 , 10 000 , 10 000
81<>
- 625 >, 82<> 58
8281 343 58 :Cl, :- 10 , - 14 , - 625 >, 83<> 000 10 000
Chlorine atom 1 is in the x,z plane, as required by convention. So we leave it alone. To put chlorine atom 2 exactly in its place, use RotationMatrix3Dz@-2 Π 3D.: :-
8281 10 000
,-
8281
3
10 000
,-
58 625
8281 5000
, 0, -
58 625
>
>
Note the infinite precision radical that has appeared. Now chlorine atom 3 must be at RotationMatrix3Dz@-4 Π 3D.:
8281 5000
, 0, -
58 625
>
111
Symmetry Theory
:-
8281
8281
3
, 10 000
,-
10 000
58 625
>
Copy and Paste these positions into to list below, and Enter it : chloroformList3 = : :"C", :0, 0, :"H", :0, 0,
5231 10 000 15 961
>, 8"1", "C3v"<>,
>, 8"1"<>, 10 000 8281 58 :"Cl", :0, ,>, 8"1"<>, 5000 625 :"Cl", :
8281
:"Cl", :-
3
,-
10 000 8281
3
10 000
8281 10 000
,-
,-
8281 10 000
58 625
,-
>, 8"2"<>,
58 625
>, 8"3"<>>;
Finally, put the molecule into the package : ListToMolecule[chloroformList3 ,"chloroformExact"]
112
10. The point groups Preliminaries
10.1. Introduction So far we have seen two kinds of symmetry matrices that apply to molecules: rotation and reflection. But the fundamental theorem makes it clear that any new kind of matrix that can be generated from these by multiplication must also be accepted as a symmetry matrix on its own. In this chapter we will do exactly that, producing three new kinds of symmetry matrices that apply to molecules. That will make five kinds in all. We will then reclassify them as just two kinds, and show that nothing fundamentally new can come from multiplying them together. The groups made from matrices of these kinds are called point groups.
10.2. The unit matrix The first example is rather trivial, but it points the way to two other developments that are not so trivial. Suppose you examine a flat, but otherwise unsymmetrical molecule. The plane of the molecule is a reflection plane in which every atom remains unmoved, so it is a symmetry element for the molecule. Let the x,y axes lie in the plane of the molecule, with z perpendicular to it. The reflection matrix Σz is predefined in the Symmetry` package, as is the unit matrix Emat : 8Σz , Emat< MatrixList 1 0 0 : 0 1 0 , 0 0 -1
1 0 0 0 1 0 > 0 0 1
Multiply Σz by itself : Σz .Σz == Emat
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_10, © Springer Science+Business Media, LLC 2009
113
Symmetry Theory
True
Further multiplications yield nothing new, so the Fundamental Theorem says that 8Σz , Emat< must be a group, and Emat must be accepted as a kind of symmetry matrix for the molecule. So now we have three distinct kinds of symmetry matrix: Σ matrices (reflections), C matrices (rotations), and Emat (the unit, or identity, matrix).
10.3. The inversion matrix The symmetry group of a brick is one of the easiest to visualize. Simple as it is, the brick generates a surprise gift; a new kind of symmetry transform, not a rotation nor a reflection nor the identity, but another kind of symmetry matrix that is required to exist by the fundamental theorem. Imagine before yourself a perfect brick, centered squarely in an x,y,z coordinate system. (If you do not see one, choose the closed cell just below and process it, and such a brick will appear.)
Z Y
X
Fig. 10.1 A brick, centered squarely on the axes, with reflecting planes
We notice that each of the coordinate planes (x = 0, y = 0, and z = 0) is a reflection plane for the brick. We put them together, along with Emat, as a list of matrices
114
Inversion matrix
mats1 = 8Emat, Σx , Σy , Σz <; Map@MatrixForm, mats1D 1 0 0 : 0 1 0 , 0 0 1
-1 0 0 0 1 0 , 0 0 1
1 0 0 0 -1 0 , 0 0 1
1 0 0 0 1 0 > 0 0 -1
Give them string symbolic names : names1 = 8"E", "Σx ", "Σy ", "Σz "<; Now using these names, we test the list of matrices for closure, to see if they form a group: MultiplicationTable@Dot, mats1, names1D MatrixForm E
Σx Σy Σz
Σx E Σy ?
? E
? ?
Σz ?
?
E
No they do not; all the Σ.Σ products are missing. For example, Σx . Σy is missing. Σx .Σy MatrixForm -1 0 0 0 -1 0 0 0 1
A little thought shows that this ought to be the same as a rotation by half a turn about z, but we check to make sure : Cz @ΠD == Σx .Σy True
Yes, of course, two-fold rotations about the coordinate axes are indeed symmetry operations for the brick. They are just as obvious as the reflections, once they are pointed out. This little mistake emphasizes nicely that the rotation axes are a logical consequence of the reflection axes, and not some completely new kind of symmetry. We extend our list of matrices and names to include the 115 rotations :
Yes, of course, two-fold rotations about the coordinate axes are indeed symmetry operations Symmetry Theoryfor the brick. They are just as obvious as the reflections, once
kind of symmetry. We extend our list of matrices and names to include the rotations : C2 x = Cx @ΠD; C2 y = Cy @ΠD;
C2 z = Cz @ΠD; C2mats = 8C2 x , C2 y , C2 z <;
C2names = 8"C2 x ", "C2 y ", "C2 z "<; mats2 = Join@mats1, C2matsD; names2 = Join@names1, C2namesD; Map@MatrixForm, mats2D 1 0 0 : 0 1 0 , 0 0 1 1 0 0 0 1 0 , 0 0 -1
-1 0 0 0 1 0 , 0 0 1
1 0 0 0 -1 0 , 0 0 1
1 0 0 0 -1 0 , 0 0 -1
-1 0 0 0 1 0 , 0 0 -1
-1 0 0 0 -1 0 > 0 0 1
All these matrices are very simple; they are all based on various negations of the 1's on the diagonal of the unit matrix . Now, with the three rotations added, does the table close? MultiplicationTable@Dot, mats2, names2D MatrixForm E
Σx
Σy
Σx
E
C2 z C2 y ?
Σz
Σy
C2 z E
Σz
C2 x C2 y C2 z
C2 x Σz
Σz
Σy
?
Σx ?
C2 y C2 x E
Σy
Σx
C2 x ?
Σz
Σy
E
C2 z C2 y
C2 y Σz
?
Σx
C2 z E
C2 z Σy
Σx
?
C2 y C2 x E
C2 x
Not quite. For instance, Σx .C2 x must still be included. We look at it: Imat = Σx .C2 x ;
MatrixForm@ImatD
-1 0 0 0 -1 0 0 0 -1
This matrix, which we call Imat, has the only pattern of diagonal negation that was missing from the list mats2. Imat is a new kind of symmetry operation 116 that we have not seen before; it is not the identity, nor a rotation about any axis, nor a reflection in any plane. It is called the inversion, and is perhaps best described as a three simultaneous reflections in the three coordinate planes.
Inversion matrix
This matrix, which we call Imat, has the only pattern of diagonal negation that was missing from the list mats2. Imat is a new kind of symmetry operation that we have not seen before; it is not the identity, nor a rotation about any axis, nor a reflection in any plane. It is called the inversion, and is perhaps best described as a three simultaneous reflections in the three coordinate planes.
Inversion The inversion is the simultaneous negation of all coordinates; i.e., it is a reflection through the origin.
With the inclusion of the inversion matrix Imat , does our list of matrices close? mats3 = Join@mats2, 8Imat
Σx
Σy
Σx
E
C2 z C2 y I
Σy
C2 z E
Σz
C2 y C2 x E
C2 x I
Σz
C2 y Σz C2 z Σy I
Σz
C2 x C2 y C2 z I Σz
Σy
C2 x
I
Σx
C2 y
Σy
Σx
I
C2 z
Σy
E
C2 z C2 y Σx
I
Σx
C2 z E
Σx
I
C2 y C2 x E
C2 x Σz
C2 x C2 y C2 z Σx
Σy
C2 x Σy Σz
Σz E
It does close, so now we have four kinds of symmetry elements: C matrices, Σ matrices, Emat, and Imat. (This group will later be named systematically as D2 h .) It may seem a little strange to give a name and an independent existence to a symmetry operation that is easily visualized as the product of three simple reflections. Remember, we do this in order to have a complete group of symmetry operations, to which we may apply all the many subtle theorems of abstract group theory. A little strangeness here in the beginning yields a big payoff down the road. Molecules that contain an inversion center play an important role in molecular spectroscopy, because for very fundamental reasons (which we will analyze in due course) the spectroscopy of such molecules is cleaner and simpler than that of similar molecules that lack the inversion center. So inversion plays a larger role in the theory of spectroscopy than one might at first imagine. 117
MoleculesTheory that contain an inversion center play an important role in molecular Symmetry
of similar molecules that lack the inversion center. So inversion plays a larger role in the theory of spectroscopy than one might at first imagine. Once we admit the inversion as a symmetry operation on its own, it does not have to occur as a consequence of other symmetries. For instance, Emat and Imat make a two-element group all by themselves. (This group is called Ci .) MultiplicationTable@Dot, 8Emat, Imat<, 8"E", "I"
E I O I E
10.4. Roto-reflection matrices 10.4.1. A group based on “eclipsedEthane” (an S3 axis) With one more example we will complete our discoveries of new types of symmetry operators. Consider the ethylene molecule in its eclipsed configuration. This molecule will lead us to a whole new class of symmetry transforms. Here is the molecule, in a view that shows one of the H-C-C-H planes edge-on. We let this plane be the y,z plane, or the x=0 plane. eclEth = Show@AtomGraphics@"eclipsedEthane", AtomLabels ® False, AxisLength ® 2D, BondGraphics@"eclipsedEthane", 1.5`D, ViewPoint ® 80, 3, 1<, ImageSize ® 120, Boxed ® FalseD
Fig. 10.2 Ethane, in eclipsed configuration
118
Roto-reflection matrices
One view is never enough to see for sure the structure of a three-dimensional molecule. The AxialViews operator shows everything : AxialViews@eclEth, ImageSize -> 200D
Fig. 10.3 A shop drawing of eclipsedEthane
The view down the z axis shows only three H atoms because the top three are “eclipsing” the bottom three. The threefold rotation about z and the reflection in the xy plane (parallel to the z axis) are easily noticed. We have already defined matrices Emat and Σz ; now we need a rotation C3 z 2
and its square, C3 z . = RotationMatrix3Dz@2 Π 3D;
C3 z
:C3 z ,
:
1
-2 3 2
0
2 C3 z >
-
3 2
MatrixList
3
1
-2
0 ,
- 12
0
-
0
1
0
2 3 2
0
- 12
0
0
1
2
C3 z
= C3 z .C3 z ;
>
119
Symmetry Theory
We put the four matrices together and test for closure: MultiplicationTableBDot, :Emat, C3 z , C3 z , Σz >, 2
:"E", "C3 z ", "C3 z ", "Σz ">F MatrixForm 2
2
C3 z C3 z Σz
E
2
C3 z C3 z E 2 C3 z
Σz
E ?
?
C3 z ? ? E
There are four question marks. Two of them are due to 8 C3 z .Σz , Σz . C3 z < Map@MatrixForm, ðD &
-1
:
3
-
2 3
2
2
,
-1
0
0
-1
2
0
-1
0
2
3 2
0
3
-
2
0
-1
0
0
-1
2
>
These are identical. The other two question marks are due to 9 C23 z .Σz , Σz . C23 z = Map@MatrixForm, ðD & 1 4 3 4
:
3 4 1 4
0 0
,
0 0 -1
1 4 3 4
3 4 1 4
0 0
>
0 0 -1
and these are identical also. So the group needs at least two more matrices which we name as S3 z and S23 z . S3 z = C3 z .Σz ; 2
2
S3 z = C3 z .Σz ;
MapBMatrixForm, :S3 z , S3 z >F 2
120
Roto-reflection matrices
:
- 12
3
-
3 2
,
-1
0
-
0
-1
0
2
0
3
- 12
0
2
2 3 2
0
-1
0
0
-1
2
>
We rearrange the group in an order that may seem peculiar, but which we know from experience will be instructive. Then we test again for closure : MultiplicationTableB Dot, :Emat, S3 z , C3 z , Σz , C3 z , S3 z >, 2
2
:"E", "S3 z ", "C3 z ", "Σz ", "C3 z ", "S3 z ">F 2
2
MatrixForm 2
S3 z C3 z Σz
E
2
C3 z S3 z
2
S3 z C3 z Σz
2
C3 z S3 z E
2
2
C3 z Σz
C3 z S3 z E
Σz
2 S3 z
C3 z 2
2
2
E
S3 z C3 z 2
C3 z S3 z E S3 z E
S3 z
S3 z C3 z Σz 2
S3 z C3 z Σz
C3 z
Finally it closes, so this is indeed a group of matrices under Dot. Also, we notice immediately (by the purity of the counter-diagonal) that it is a cyclic group. But what is it that is cycling? It is our newly constructed matrix S3 z , which suddenly comes into focus as the fundamental generator of this group. In other words, all the other members of the group are just matrix powers of S3 z (including the unit element, which is its zeroth power and its sixth power). MatrixPower@S3 z , 6D 881, 0, 0<, 80, 1, 0<, 80, 0, 1<<
This is a group, but it is not the whole group of the eclipsed ethane molecule because we ignored the yz reflection, and two similar reflections. This is exactly how humans can easily err in assigning a molecule to a group.
10.4.2 The new symmetry element : the S3 z matrix 121
Symmetry Theory
10.4.2 The new symmetry element : the S3 z matrix Compare the matrix S3 z with the threefold rotation matrix C3 z : Map@MatrixForm, 8C3 z , S3 z
:
- 12
3
-
3 2
0
2
- 12
0 ,
- 12
0
0
1
3 2
0
-
3 2
0
- 12
0
0
-1
>
They are the same, except for the negation of the z,z element, caused by multiplying C3 z with Σz , in either order. Matrix S3 z is not a rotation about any axis nor a reflection in any plane, not the inversion, nor the identity. It is a fifth kind of symmetry matrix called a roto-reflection, a combination of a rotation about an axis followed (or preceded) by reflection in a plane perpendicular to that axis. We also see that it is a required new independent element in any group that contains a rotation and a reflection parallel to that rotation's axis. Just as rotation axes are always denoted by C, rotoreflection axes are always denoted by S. Again, you may find it strange to give a name and an independent existence to a combination that is so easily visualized in terms of two more intuitive operations. And again we can only say that this is an essential part of creating groups of symmetry operations, which has such a big payoff later on. Look at the six H atom lists of the “eclipsedEthane” molecule : sixHlistEclipsed = Take@MoleculeToList@"eclipsedEthane"D, 6D; Column@sixHlistEclipsedD :H, :0, 1, :H, ::H, :
122
3 2 3 2
3 >, 2
81, S3<>
, - 12 , - 32 >, 82<>
, - 12 ,
3 >, 2
83<>
Roto-reflection matrices :H, :0, 1, - 2 >, 84<> 3
:H, ::H, :
3 2 3 2
1
, -2,
3 >, 2
85<>
, - 2 , - 2 >, 86<> 1
3
Make a “molecule” that omits the two C atoms, for visual clarity : ListToMolecule@sixHlistEclipsed, "sixHeclipsed"D; Starting with the coordinates of H atom 1, we can generate the positions of all the other H atoms by repeated application of S3 z . The operator NestList does exactly this. Use the ? to look at its syntax. NestList@Sin, Α, 3D 8Α, Sin@ΑD, Sin@Sin@ΑDD, Sin@Sin@Sin@ΑDDD<
As advertised, it applied the Sin operator to Α, 0 times through 3 times. We want to take a particular position in space (the location of H atom 1 in eclipsedEthane) and multiply is from the left by matrix S3 z , 0 times through 6 times. To avoid having to name this multiplication operator, we write in the anonymous form S3 z .ð & . Note: If you want to understand this completely right now, go the Documentation Center and read the tutorial on “Pure Functions”. Pure functions have no function name. So it might be better to call them “anonymous functions”.
Hpos1 = 80, 1, 3 2<; lineEclipsedH6 = NestList@S3 z .ð &, Hpos1, 6D ::0, 1,
3 2
:0, 1, -
>, :3 2
>, :-
3
,-
2
1
,-
2 3 2
,-
3 2
1
3 ,
2
2
>, : >, :
3
,-
2 3 2
1 2
,-
3 ,
1 2
2 ,-
>, 3 2
>, :0, 1,
3 2
>>
Options@AtomGraphicsD
8AxisLength ® Automatic, AtomDiameterFactor ® 1, AtomLabels ® True, ViewPoint ® 8-3, -24, 20<, , ,
123
Symmetry Theory
BaseStyle ® Text, Boxed ® False, ImageSize ® 8250, 250<, Lighting ® Neutral<
Note that these points are identical to the H atoms positions in sixHlist Eclipsed. The sixth one is identical to the first one, so it is a cycle. Make a red track that helps the eye to follow the atoms in order : zigzagEcl = Graphics3D@8Red, Thickness@0.01`D, Line@lineEclipsedH6D
Fig. 10.4 Atom positions generated by repeated application of S3 z to position 1. Grab it and rotate it to see it from other view points.
Letting your eye follow the numbers, you see what S3 z does to each H atom: It advances by 1/3 turn, and also flips between bottom and top. Note particularly that it has to go around the circle twice to hit all six atoms.
10.4.3. Generalization to Sn
This is such a useful idea that we immediately generalize it :
124
Roto-reflection matrices
Sn operation Operation Sn is a right handed rotation by 2Π/n radians, plus a reflection in a plane perpendicular to the rotation axis, and passing through the origin .
On your own Show that it does not matter whether the rotation or the reflection is done first.
Carrying out the definition above as RotationMatrix3D@ΒD.Σz , we find that roto-reflection by angle Β about the z axis is given by Sz @Β_D :=
Cos@ΒD -Sin@ΒD 0 Sin@ΒD Cos@ΒD 0 0 0 -1
We evaluate the case of roto-reflection by 1/6 of a turn : S6 z = Sz @2 Π 6D; MatrixForm@S6 z D
1 2
3
3 2
0
2
0
1 2
0
0
-1
Mathematica has a handy core operator for taking matrix powers. We use it to take the 5th matrix power of S6 z ; i.e., the result of matrix multiplying S6 z with itself 5 times : S6 z = MatrixPower@S6 z , 5D; MatrixFormBS6 z F 5
5
3
1 2
0
2 3 2
0
1 2
0
0
-1
125
Symmetry Theory
Just as a check, we also do it the primitive way : 5
S6 z == S6 z .S6 z .S6 z .S6 z .S6 z True
This is very different from the numerical 5th power of S6 z , given by HS6 z L5 ::
1
,-
32
9
3 32
, 0>, :
9
3
1 ,
32
32
, 0>, 80, 0, -1<>
Do you remember what the numerical power of a matrix is? If you are puzzled, take the numerical fifth power of a symbolic matrix {{a,b},{c,d}}. Hint: This arises because Power is Listable , which means “automatically mapped”. To see this for yourself, look at Attributes[Power]. Because rotations about z commute with reflections parallel to z, it is easy to m
show that all Sn matrices about the z axis are of the form
m_ Sn_
CosA 2 Πn m E -SinA 2 Πn m E :=
SinA 2 Πn m E
CosA 2 Πn m E
0
0
0 0
H-1Lm
We will not use this form very often, but here it helps to make an important point. Below, for the case n = 6, we tabulate the rotation angle 2Π*m/6 together m
with the associated matrix S6 : TableB:2 Π m 6, S6 >, 8m, 0, 6
Map@MatrixForm, ð, 82
Π 1 2Π 2 4Π 4 5Π 5 0 3 6 ::0, S6 >, : , S6 >, : , S6 >, :Π, S6 >, : , S6 >, : , S6 >, :2 Π, S6 >> 3 3 3 3
Above we see that the matrices of an S6 axis start out as a unit matrix when the angle is 0, and come back to the unit matrix after a rotation of 2Π, giving a group of 6 matrices. All even-fold axes do a qualitatively similar thing. But look at the behavior of an odd axis. We take S3 as the example : 126
Roto-reflection matrices
group of 6 matrices. All even-fold axes do a qualitatively similar thing. But look at the behavior of an odd axis. We take S3 as the example : TableB:2 Π m 3, S3 >, 8m, 0, 6
Map@MatrixForm, ð, 82
::0, S3 >, : 0
2Π
, S3 >, :
3
1
4Π 3
, S3 >, :2 Π, S3 >, : 2
3
8Π 3
, S3 >, : 4
10 Π
, S3 >, :4 Π, S3 >> 5
6
3
After a rotation of 2Π, the S3 axis gives a reflection matrix. It does not return to a unit matrix until it has completed a rotation of 4Π, so the cycle has 6 matrices in it, just as did the S6 axis. The general rule is not hard to see:
When n is even, the Sn axis yields n matrices, and has a cycle of 2Π radians. But when n is odd, the Sn axis yields 2n matrices and has a cycle of 4Π radians.
10.4.4. The “staggeredEthane” molecule; an S6 axis 8Σz , Emat< 8881, 0, 0<, 80, 1, 0<, 80, 0, -1<<, 881, 0, 0<, 80, 1, 0<, 80, 0, 1<<<
This whole section is almost a mechanical copy of parts of Subsection 10.4.1, on “eclipsedEthane”. We have changed it to a discussion of “staggeredEthane”, another predefined molecule in the package Molecules`, by making the minimum necessary changes. stgEth = Show@AtomGraphics@"staggeredEthane", AtomLabels ® False, AxisLength ® 0D, BondGraphics@"staggeredEthane", 1.5`D, ViewPoint ® 80, 30, 6<, ImageSize ® 90, Boxed ® FalseD
127
Symmetry Theory
Fig. 10.5 Ethane in its “staggered” configuration.
The difference is that the bottom CH3 group has been rotated by half a turn about the C-C axis. AxialViews@stgEth, AtomLabels -> False, ImageSize -> 200D
Fig. 10.6 Shop drawing of staggered ethane.
Now the view down the C-C axis shows all six H atoms; formerly, the top three “eclipsed” the bottom three. sixHlistStaggered = Take@MoleculeToList@"staggeredEthane"D, 6D; Column@sixHlistStaggeredD
128
Roto-reflection matrices :H, :0, 1, :H, :-
3 2
:H, :-
3
3 >, 2
,
1 , 2
,-
81, S6<>
- 3 >, 82<> 2
1 3 , 2 >, 2
83<>
:H, :0, -1, - 32 >, 84<> :H, : :H, :
2
3 2 3 2
, - 12 , 1 , 2
,
3 >, 2
85<>
- 32 >, 86<>
We make this atom list into an official molecule (omitting the C atoms for visual clarity) : ListToMolecule@sixHlistStaggered, "sixHstaggered"D; Make a list of all the staggered H atom positions, in sequence : lineStaggeredH6 = NestList@S6 z .ð &, 80, 1, 3 2<, 6D ::0, 1,
3 2
>, :-
:0, -1, -
3 2
>, :
3
1 ,
2
,-
2 3
,-
2
3 2
1
>, :3
, 2
2
>, :
3
,-
2
3 ,
2
3
1 ,
2
1
2
,-
2 3 2
>, >, :0, 1,
3 2
>>
Put the picture together :
129
Symmetry Theory
Fig. 10.7 Repeated applications of S6 z to position 1.
Letting your eye follow the numbers, you see what S6 z does to each H atom: It advances by 1/6 turn, and also flips between bottom and top. It hits each atom during one full rotation, because 6 is even. This differs from the eclipsed situation, where we used S3 z . Because 3 is odd, it took two full rotations to hit each of the six atoms once.
10.4.5. The nature of S2 : it's the same as the inversion Visualize a roto-reflection S2 z about the z axis by half a turn. For any point {x,y,z}, the reflection part changes the sign of the z, while the rotation by half a turn about z changes the sign of both x and y. So it is exactly the same as an inversion. We construct such a twofold rotoreflection matrix : S2 z = RotationMatrix3Dz@ΠD . Σz ; MatrixForm@S2 z D -1 0 0 0 -1 0 0 0 -1
This is the inversion matrix Imat, confirming the answer by visualization. Now we show that the same is true, regardless of the axis you use. In Chapter 12 (LieRotations), (click for a preview) we will develop a general operator for rotoreflection about an arbitrary axis by arbitrary angle, and an operator for reflection in a mirror with arbitrary normal. We jump ahead a little and use them to make the matrix of an S2 operator with an arbitrarily oriented axis. First we make the axis : 130
This is the inversion matrix Imat, confirming the answer by visualization. Now we show that the same is true, regardless of the axis you use. In Chapter 12 (LieRotations), (click for a preview) we will develop aRoto-reflection general operator for matrices
them to make the matrix of an S2 operator with an arbitrarily oriented axis. First we make the axis : arbitraryAxis = RandomReal@80, 1<, 3D 80.409513, 0.954485, 0.166154<
Reflection parallel to this axis is Σarb = AxialReflection@arbitraryAxisD; % MatrixForm 0.696839 -0.706601 -0.123003 -0.706601 -0.646933 -0.286694 -0.123003 -0.286694 0.950093
Rotation by half a turn about it is Carb @ΠD = AxialRotation@arbitraryAxis, ΠD; % MatrixForm -0.696839 0.706601 0.123003 0.706601 0.646933 0.286694 0.123003 0.286694 -0.950093
So rotoreflection by half a turn about the arbitrary axis is HΣarb .Carb @ΠDL ChopInteger MatrixForm -1 0 0 0 -1 0 0 0 -1
It's still the inversion matrix. Therefore, Σarb .Carb @ΠD (or Carb @ΠD.Σarb , as you may try for yourself) is the inversion matrix, regardless of the axis direction.
131
Symmetry Theory
10.5. Only two kinds of matrices Now that we have the rotoreflection axis as a concept, we begin to see our situation more clearly. Every symmetry transform we have discussed is either proper or improper .
The proper transforms are all rotations plus the identity. The improper transforms are inversion.
all retroflections, all reflections, and the
We will show below that the generalized multiplication table for Proper and Improper transform matrices is
Dot Proper Improper Proper Proper Improper Improper Improper Proper Fig. 10.8 Multiplication for proper and improper unitary matrices.
10.5.1. Proper transforms For instance, what is rotation by zero angle? It's nothing; or in more formal words, it is the identity operation, carried out by Emat. Look at the general and special cases together : 8Cz @ΦD, Cz @0D< MatrixList Cos@ΦD -Sin@ΦD 0 : Sin@ΦD Cos@ΦD 0 , 0 0 1
1 0 0 0 1 0 > 0 0 1
The determinant of all proper rotations is 1 : Det@Cz @ΦDD TrigReduce 1
10.5.2. Improper transforms 132
Only two kinds
10.5.2. Improper transforms Similarly, what is rotoreflection by zero angle? The rotation does nothing, but the reflection still operates, so this is what we have so far called “reflection”. For example, 8Sz @ΦD , Sz @0D , Σz < MatrixList Cos@ΦD -Sin@ΦD 0 : Sin@ΦD Cos@ΦD 0 , 0 0 -1
1 0 0 0 1 0 , 0 0 -1
1 0 0 0 1 0 > 0 0 -1
So {rotations,identity} are proper and {rotoreflections, reflections} are improper. This leaves only the inversion matrix as a possibly different kind of operation. But think about rotoreflection by half a turn. In the plane perpendicular to the rotation axis, each of the in-plane axes has its sign reversed by the half-turn rotation, and then the sign of the rotation axis is changed by the reflection. Together, these makes an inversion; so the inversion, too, is just a special case of rotoreflection. For instance, 8Sz @ΦD , Sz @ΠD , Imat< MatrixList Cos@ΦD -Sin@ΦD 0 : Sin@ΦD Cos@ΦD 0 , 0 0 -1
-1 0 0 0 -1 0 , 0 0 -1
-1 0 0 0 -1 0 > 0 0 -1
The determinant of all improper rotations is -1 : Det@Sz @ΦDD TrigReduce -1
10.5.3. Nothing left to discover We state a pair of theorems that tie this chapter up quite neatly, but which we are not yet ready to prove. The proof will appear later in the book .
133
Symmetry Theory
A pair of theorems If the determinant of a matrix is +1, the matrix represent a proper rotation. If the determinant of a matrix is -1, the matrix represents a rotoreflection (an improper rotation).
Now we couple this with a standard theorem from the theory of determinants. Using the Mathematica operator Det for the determinant, it is
If Amat and Bmat are square matrices of the same size, then Det[Amat] Det[Bmat] == Det[Amat.Bmat]
On your own Make two different 3´3 matrices filled with random real numbers, and test this out. Random real numbers, uniformly distributed from 0 to 1, are returned by Random[].
In view of the theorems above, the generalized multiplication table for Proper and Improper transform matrices must be that shown above as Fig. 10.7. There is something in this table that many people find surprising: an Improper times an Improper is always a Proper. Therefore, a reflection times a reflection is a rotation. Ponder this. It does make sense. The closure of this table means that we can never make anything fundamentally new by combining Proper and Improper transforms. It also means that all Proper and Improper matrices of the same size (think 3´3) form a group under Dot.
Point Group The group of all proper rotation and improper rotation matrices is the Point Group. Chemists and physicists rarely use the whole point group. Point Groups The plural refers to finite subgroups of the whole infinite Point Group. These small subgroups describe molecular symmetries.
The name Point Group reminds us that only one point (namely, the origin) is symmetric under all of these transforms. Every molecule of finite size has a 134 unique point, its center of mass. This is the point which must be used as the origin of all the symmetry rotations and rotoreflections of the molecule. It is returned by the package operator CenterOfMass["molecule name"].
Only two kinds
The name Point Group reminds us that only one point (namely, the origin) is symmetric under all of these transforms. Every molecule of finite size has a unique point, its center of mass. This is the point which must be used as the origin of all the symmetry rotations and rotoreflections of the molecule. It is returned by the package operator CenterOfMass["molecule name"]. Also, a correct set of symmetry axes for the molecule is generated automatically by InertiaTensor["molecule name"].
10.5.4. Coming attractions The point group is of infinite order, but any given molecule is described by a small finite subgroup of this infinite group. The description and naming of all possible finite subgroups of the infinite point group will be the subject of Chapter 17. But first, we must study how groups are constructed, because the names are actually very succinct coded instructions on how to construct them. So in Chapter 11 and Chapter 12 we study the construction of individual rotation and rotoreflection matrices. In Chapter 13 we make an inverse operator that works on any point group matrix, returning its axis and rotation (or roto-reflection) angle. Then in Chapter 15 we make an operator that accepts two or three point group matrices as input, returning the whole groups implied by the input matrices. Finally in Chapter 17 we will be ready for the naming of the Point Groups.
135
11. Euler rotation matrices Preliminaries
11.1 The Euler idea We have so far considered only rotations about the coordinate axes. But molecules often contain rotations axes at some cockeyed angle, and we now have to learn how to deal with that. We will show two ways, the Euler rotation matrix (this chapter) and the Lie rotation matrix (next chapter). Consider a solid object, oriented in some standard position. To be concrete, think of a cylindrical drinking glass in a defined standard position: standing upright, with a decoration on one side facing, say, South. Consider also a Cartesian coordinate system, z axis pointing up and x axis pointing East. How can we use this coordinate system to specify a series of rotations that will take the drinking glass into absolutely any other orientation? Here is the answer given by Leonard Euler ( pronounced “oiler”, Swiss mathematical genius, 1707-1783) : Think of the object as possessing a body-fixed axis (in our case, say, the cylindrical axis of the glass). If you can turn the body axis (and the body with it ) in any desired direction, and if you can then turn the glass about its body axis (to make the decoration take any desired direction around the body axis) then you have finished the job. How many rotations will this require? Just as positions on the earth require a latitude angle and a longitude angle, the positive end of the body axis requires two coordinate angles to specify its direction. The final rotation about the body axis is a third rotation, and thus we have “the three Euler angles”. This sounds simple enough, but in a bare x,y,z coordinate system there are many ways to specify those latitude and longitude angles, and each way requires a different final body axis angle. The devil is in the details. We will adopt the Euler conventions of A. R. Edmonds, who is consistent with Herzberg and uniquely consistent with the Condon-Shortley convention for the spherical harmonics, now almost universally adopted.
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_11, © Springer Science+Business Media, LLC 2009
137
Symmetry Theory
11.2 The Euler rotations visualized In Fig. 1 below, we see four superposed coordinate systems with flags of different colors. After each motion one coordinate system will be left in place as a marker of where the moving system has been.
Fig. 11.1 Four flagged axis systems in original position
For Fig. 2, rotate by Φ about the z-axis. In the figure below, Φ = 2 Π/6 . The black “space-fixed” axes are left behind. The rotation is counterclockwise as viewed from the positive z axis, as it should be for a positive angle.
Fig. 11.2 First Euler rotation, by Φ about z. The black space-fixed system stays behind.
For Fig. 3, rotate by Θ around the body-fixed y axis (here red and green, accompanied temporarily by blue). The only axes that move are the coincident z and x axes in green and blue. The matrix is Rot2 = Rot1 .Cy @ΘD.Rot-1 , 138 where in Fig. 3 below, Θ = 2Π/15.
Euler visualized
z and x axes in green and blue. The matrix is Rot2 = Rot1 .Cy @ΘD.Rot-1 , where in Fig. 3 below, Θ = 2Π/15.
Fig. 11.3 Second Euler rotation. The red system stays behind as the blue and green systems rotate about the blue and green y-axis. The blue z axis (the body axis) is in final position.
For Fig. 4, rotate about the body axis by Rot3 . For this, undo the second rotation, then undo the first rotation then rotate by Ψ about z, then redo the first two rotations: Rot3 = Rot2 .Rot1 .Cz @ΨD.Rot-1 .Rot-2 . We take Ψ = .41 Π.
Fig. 11.4 Third Euler rotation. The green system stays behind as the blue system rotates about its own z-axis (the body axis). The large blue flags indicate the final coordinate system position.
139
Symmetry Theory
11.3 The Euler matrix theorem Now you are about to witness an algebraic miracle; a geometric property that is true, but essentially impossible for humans to visualize. We begin by collecting together the three Euler rotations we used in the last section, but we use capital axis indices because (for example) Cz is automatically evaluated, but CZ is not. The first rotation and its inverse are Clear@Φ, Θ, ΨD; Rotn1 = CZ @ΦD; Rotn-1 = CZ @-ΦD; The second rotation and its inverse are
Rotn2 = Rotn1 .CY @ΘD.Rotn-1 ; Rotn-2 = Rotn1 .CY @-ΘD.Rotn-1 ;
The third rotation is
Rotn3 = Rotn2 .Rotn1 .CZ @ΨD.Rotn-1 .Rotn-2 ;
Now the total Euler rotation matrix is given by Rotn3 .Rotn2 .Rotn1
CZ @ΦD.CY @ΘD.CZ @-ΦD.CZ @ΦD.CZ @ΨD.CZ @-ΦD. CZ @ΦD.CY @-ΘD.CZ @-ΦD.CZ @ΦD.CY @ΘD.CZ @-ΦD.CZ @ΦD
This result can be simplified a lot. We repeat it below, with cancelling neighbors colored red : CZ @ΦD.CY @ΘD.CZ @-ΦD.CZ @ΦD.CZ @ΨD.CZ @-ΦD. CZ @ΦD.CY @-ΘD.CZ @-ΦD.CZ @ΦD.CY @ΘD.CZ @-ΦD.CZ @ΦD
Cancelling the red pairs, we create one more cancelling pair : CZ @ΦD.CY @ΘD.CZ @ΨD.CY @-ΘD.CY @ΘD
The final miraculous result is CZ @ΦD.CY @ΘD.CZ @ΨD
We recapitulate this result as sacred words, never to be violated for any reason :
140
Euler theorem
Euler angles First, rotate the solid body by Ψ about z. Second, by Θ about y. Third, by Φ about z (again). Axes x, y, and z are fixed in space and do not rotate.
11.4 The function EulerMatrix[Φ, Θ, Ψ] Now it is very easy to calculate the Euler matrix in terms of trigonometric functions. Just replace the dummy capital letter axes by lower case letters; then Cx , Cy , and Cz automatically turn into a rotation matrix formulas: EuMat = Cz @ΦD.Cy @ΘD.Cz @ΨD;
EuGrid = Grid@EuMat, Dividers ® AllD Cos@ΘD Cos@ΦD Cos@ΨD - -Cos@ΨD Sin@ΦD Cos@ΦD Sin@ΘD Sin@ΦD Sin@ΨD Cos@ΘD Cos@ΦD Sin@ΨD Cos@ΘD Cos@ΨD Sin@ΦD + Cos@ΦD Cos@ΨD Sin@ΘD Sin@ΦD Cos@ΦD Sin@ΨD Cos@ΘD Sin@ΦD Sin@ΨD -Cos@ΨD Sin@ΘD Sin@ΘD Sin@ΨD Cos@ΘD
The whole calculation is (3rd.2nd.1st).vec., where “Ψ about z” is 1st, etc. The Euler matrix is always at hand in the Symmetry` package: ? EulerMatrix EulerMatrix@Φ,Θ,ΨD or EulerMatrix@8Φ,Θ,Ψ
We check that the EulerMatrix in Symmetry` is the same as EuMat defined above : EulerMatrix@Φ, Θ, ΨD == EuMat True
For a further comment on Edmonds, click here, or flip to the End Notes.
11.5 Euler headaches 141
Symmetry Theory
11.5 Euler headaches 11.5.1 The 96 possible Euler matrices In defining a space-fixed Euler rotation, there are 3 coordinate axes from which to pick the first rotation axis, and 2 from which to pick the second. (The third is always the same as the first.) Aside from that, you could in principle take any of the rotations to be right handed or left handed. That makes (3*2)*(2*2*2) = 48 possible Euler matrices right there, and probably all of them have been used at one time or another. And of course any of them could be defined to act to the right or to the left, doubling the confusion again to 96. If an author does not state his Euler convention clearly, it may take many tries for a reader to hit the right combination.
11.5.2 Even worse Even if everyone could agree on a standard Euler rotation, our troubles would not be over. Very often you need to rotate a body from one non-standard orientation to another. There are always Euler angles that will do this, but they may be fiendishly difficult to visualize. For example, consider a unit cube and its {1,1,1} diagonal axis :
z
y x
Question: What Euler angles describe a rotation of 1/3 turn about this axis? Think about this a little. This is a particularly easy and symmetric case, but if you get the answer without peeking at the end of the chapter, you may declare yourself a visual genius. 142
Euler headaches
you get the answer without peeking at the end of the chapter, you may declare yourself a visual genius. For all their importance in physics, the Euler angles are a dreadful way to do geometry. In the next chapter, we show a much better way.
11.6 The inverse function EulerAngles[matrix] 11.6.1 Basic algorithm Given a rotation matrix, it is quite possible to find the Euler angles of the rotation it represents. We repeat the general Euler matrix : EuGrid Cos@ΘD Cos@ΦD Cos@ΨD Sin@ΦD Sin@ΨD Cos@ΘD Cos@ΨD Sin@ΦD + Cos@ΦD Sin@ΨD -Cos@ΨD Sin@ΘD
-Cos@ΨD Sin@ΦD Cos@ΘD Cos@ΦD Sin@ΨD Cos@ΦD Cos@ΨD Cos@ΘD Sin@ΦD Sin@ΨD Sin@ΘD Sin@ΨD
Cos@ΦD Sin@ΘD Sin@ΘD Sin@ΦD Cos@ΘD
We take a numerical example : rotmat = EulerMatrix@1., 2., 4.D; % Grid@ð, Dividers ® All, Spacings ® 82, 2
0.379859
0.491295
-0.180012
-0.618179
0.765147
0.594356
-0.688159
-0.416147
Pretend that we do not to know the Euler angles {1.,2.,4.} that created this matrix. Can we find them just from the numerical matrix alone? We can certainly extract Θ by taking the ArcCos of element P3,3T, a simple Cos[Θ] : ArcCos@rotmatP3, 3TD 2.
Yes, 2. is exactly the angle we used as input for Θ. But of course there is the domain issue. Check out Mathematica's ArcCos function:
143
Symmetry Theory
ArcCos@Cos@ΘDD Π
0 -1
0
1
Cos@ΘD
The returned angle will always be between 0 and Π, which is nice, because that is the defined domain of Θ.
We can calculate Ψ similarly because element P3,2T divided by the negative of element P3,1T is Tan[Ψ]. If we use the two-parameter ArcTan function, we will get Ψ without ambiguity in the range -Π to +Π. We use the same numerical example again : oldΨ = ArcTan@-rotmatP3, 1T, rotmatP3, 2TD -2.28319
Our input was 4., not this. But the trouble is trivial; Mathematica's ArcTan has branch cuts at ±(odd n)Π, and it has reported our input, minus 2Π .
ArcTan@Cos@ΘD, Sin@ΘDD ΘOut Π
-2 Π
2Π
ΘIn
-Π
This is easily fixed. The function Mod[x,n] divides x by n and returns the remainder, which is always a number between 0 and n. So if we Mod by 2Π the function becomes
Mod@ArcTan@Cos@ΨD, Sin@ΨDD, 2ΠD ΨOut 2Π Π
-2 Π
2Π
ΨIn
Now the output is always between 0 and 2Π , the defined domain of Ψ.
144
EulerAngles[matrix]
newΨ = Mod@ArcTan@-rotmatP3, 1T, rotmatP3, 2TD, 2 ΠD 4.
That was exactly the input. The Mod operator is only for the mental convenience of humans; Mathematica does not care about the {0,2Π} convention : 8Cos@oldΨD == Cos@newΨD, Sin@oldΨD == Sin@newΨD< 8True, True<
Now finally we find Φ from a similar pair of rotation matrix elements in a similar way : Φ = Mod@ArcTan@rotmatP1, 3T, rotmatP2, 3TD, 2 ΠD 1.
There, we have recovered all three Euler angles. This algorithm is embodied in the package operator EulerAngles. We try it out on our demo case : EulerAngles@rotmatD 81., 2., 4.<
Each Euler angle is in its conventional range, to avoid confusing humans.
11.6.2 Exceptional cases Most rotation matrices lead to a unique set of Euler angles. But some do not, and the EulerAngle operator must deal with them correctly. For instance, when Θ = 0, the matrix represents two consecutive rotations about z, and clearly the angles Φ and Ψ should add. eum102 = EulerMatrix@1., 0, 2.D; % MatrixForm -0.989992 -0.14112 0 0.14112 -0.989992 0 0 0 1
Its inverse is not well defined, but if you try it you get the best answer available : EulerAngles@eum102D
Rotation about the z axis Euler angles are not unique General solution is 8Φ,0,Ψ<, where Hin the given caseL Φ+Ψ = 3. 80, 0, 3.<
Another exceptional case occurs when Θ = Π. Here the final body axis is the negative of the initial body axis, so the first and third Euler angles operate 145 around the same axis, but in opposite directions. Give this one to our operator:
Symmetry Theory
Another exceptional case occurs when Θ = Π. Here the final body axis is the negative of the initial body axis, so the first and third Euler angles operate around the same axis, but in opposite directions. Give this one to our operator: eum1Π2 = EulerMatrix@1., Π, 2.D; eum1Π2 MatrixForm -0.540302 0.841471 0 0.841471 0.540302 0 0 0 -1
EulerAngles@eum1Π2D
Rotation about an axis in the xy plane Euler angles are not unique General solution is 8Φ,Π,Ψ<, where Hin the given caseL Φ-Ψ = -1. 80, 3.14159, 1.<
The EulerAngles operator again gives the best available answer. But check that it is really correct : EulerMatrix@0, Π, 1.D == EulerMatrix@1., Π, 2.D True
To see how the operator does this, open up the Private section of the file UrSymmetryV6.nb and Find the operator name.
11.7 End notes 11.7.1 Edmonds's two Euler matrices We use the Euler matrix from p. 8 of A. R. Edmonds, Angular Momentum in Quantum Mechanics. But there is another one on p. 53 that is not the same. The difference is that on p.8 the reference frame is fixed and the body moves, whereas on p.53 the body is fixed and the reference frame moves. Therefore, the two Euler matrices are inverse to each other. Throughout this book, the frames are fixed and the bodies move, as on p. 8 of Edmonds.
146
End Notes
11.7.2 Answer to the Euler puzzle What axial Euler rotations are equivalent to a third of a turn about axis {1,1,1}? Going left to right, top to bottom, the figures show (1) original position (2) after Ψ = Π/2 about z (3) after Θ = Π/2 about y This completes the puzzle: the yellow, green and red balls have rotated a third of a turn about the diagonal axis, through the final blue ball position. For completeness, the fourth figure shows a Null rotation about z again : (4) after Φ = 0 about z. Since it really needs only two axial rotations, this should be especially easy for humans. But it isn't.
147
12. Lie's axis-angle rotations Preliminaries
12.1 Introduction This chapter presents an alternative to the Euler rotation formula, a formula that returns the rotation matrix as a function of any given axis and rotation angle. But the method used is extendable in the most surprising directions, and with the most profound consequences for symmetries in physics. The method was invented by the Norwegian mathematician Sophus Lie (1842-1899), and it lies at the basis of what are called Lie groups. As a warm-up we will use Lie's method to construct the general 2D rotation matrix. Here we produce only the well known result, but by new thinking. Then we will extend the method to 3D, where the result is actually useful as the axis-angle formula for the rotation matrix.
12.2 Rotation matrices in 2D form a Lie group The two-dimensional rotation matrix formula derived in Chapter 4 is R2 D @Α_D := K
Cos@ΑD -Sin@ΑD O; Sin@ΑD Cos@ΑD
where Α is a free parameter. This formula produces an infinite number of rotation matrices that form a group under Dot because (1) When two R2 D matrices are dotted together, they yield a third R2 D matrix : K
Cos@ΑD -Sin@ΑD Cos@ΒD -Sin@ΒD O.K O Sin@ΑD Cos@ΑD Sin@ΒD Cos@ΒD
K
Cos@Α + ΒD -Sin@Α + ΒD O Sin@Α + ΒD Cos@Α + ΒD
TrigReduce MatrixForm
(2) The unit matrix is R2 D @0D; (3) The inverse of R2 D @ΑD is R2 D @-ΑD , and (4) Associativity is assured by the Dot product. This group is of infinite order because there is a different group element for different value of Α in the interval -Π Π These matrices W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, 149 DOI 10.1007/b13137_12, © Springer Science+Business Media, LLC 2009
(2) The unit matrix is R2 D @0D; (3) The inverse of R2 D @ΑD is R2 D @-ΑD , and (4) Associativity Symmetry Theory is assured by the Dot product.
every different value of parameter Α in the interval [-Π,Π]. These matrices therefore meet all the requirements for a Lie group : Lie group If the elements of an infinite group are given by a function of one or more continuously variable parameters, and if the function is infinitely differentiable with respect to its parameters, then the group is a Lie group.
12.3 Lie group for 2D rotation The concept of matrix exponentials lie at the heart of Lie's method. If you need a discussion of them, click here. to go into A3, the MatrixReview appendix. Here is a little calculation that must have struck Lie like a thunderbolt : he devoted his entire career to developing its amazing generalizations. It begins with the rather innocent thought that a large rotation can be built up from many repeated small rotations. What is the rotation matrix for a very small rotation ? Expand the R2 D rotation matrix as a power series, correct to third order in Α: Series@R2 D @ΑD, 8Α, 0, 3
Α2 2
+ O@ΑD4 -Α +
Α-
Α3 6
+ O@ΑD4 1 -
Α3 6
Α2 2
+ O@ΑD4
+ O@ΑD4
The zeroth order term (containing no Α) is K (linear in Α) is K
1 0 Oand the first order term 0 1
0 -Α O. We make the rotation very small, dividing the first Α 0 order term by some large N, and then we compound the small rotation by performing it N times. Passing immediately to the limit of infinite N TimingB 1 0 LimitBMatrixPowerBK O+ 0 1
0 - ΑN Α N
0
, NF, N ® ¥F
Expand ExpToTrig MatrixFormF :0.702947, K
Cos@ΑD -Sin@ΑD O> Sin@ΑD Cos@ΑD
There is no error or approximation. The limit of N rotations by Α/N is EXACTLY the rotation by Α. Alternatively, and more rapidly, 150
Lie group for 2D rotation
EXACTLY the rotation by Α. Alternatively, and more rapidly, MatrixExpBK K
0 -Α OF MatrixForm Α 0
Cos@ΑD -Sin@ΑD O Sin@ΑD Cos@ΑD
The thunderbolt is that the first order term of the matrix expansion TAKEN ALONE contains all the information in the whole matrix function. The information is extracted by Lie's trick; namely, by wrapping the first order term in MatrixExp . Click here for a discussion of how Mathematica actually computes the MatrixExp. But there is something strange here. There are plenty of matrix functions whose 1 0 0 -Α power series begins as K O+K O + ¼ . Why is it that only the 0 1 Α 0 rotation matrix R2 D reproduces itself when its first order term is exponentiated? Lie produced the definitive answer to this question. It happens because there is no other matrix function that begins this way and also produces a group of matrices as Α varies. In other words, he showed that R2 D performs the Matrix Exp trick because it also possesses the property HR2 D @ΕD.R2 D @ΕD TrigReduceL == R2 D @2 ΕD True
151
Symmetry Theory
On your own There is another useful 2´2 matrix function that produces a group of 1 Dx matrices. It is given by K O, and it represents translation in one 0 1 dimension in the sense that .K
x x + Dx 1 Dx O.K O = K O 0 1 1 1
It is a little strange that the second row is essential for calculation, but is discarded in the interpretation. However, mathematically, nothing prevents our using it in this way, 1 Α (a) Prove that matrices K O form a Lie group with parameter Α. 0 1 (b) Make it perform Lie's trick: Find the first order term and take its MatrixExp . 1 Sin@ΑD (c) As a counter-example, do the same thing on K O. Why 0 1 does the counter-example fail? Click here if you have to peek at the answer.
12.4 Lie group for 3D rotation 12.4.1 Lie's trick for axis-angle rotation in 3D Take n to be a fixed rotation axis of unit length, and let plane P be perpendicular to n. In plane P let r be a vector from the origin to any point on a unit
circle. Thus n and r are orthonormal. Some matrix QBΑ È nF(unknown to us at this point) rotates vector r by angle Α about axis n according to the formula QBΑ È nF .r = r + DrBΑ È nF The vertical bar in this symbol reminds us that Α is the Lie parameter that produces different group elements as it varies, whereas n is just an auxiliary parameter that is constant for all members of the group.
The derivative
Q¢ BΑ È nF means differentiation with respect to Α only. So the series expansion will be 152
The vertical bar in this symbol reminds us that Α is the Lie parameter that Lie group fo 3D rotation produces different group elements as it varies, whereas n is just an auxiliary Q¢ BΑ È nF means differentiation with respect to Α only. So the series expansion will be QBΑ È nF =
1 0 0 0 1 0 0 0 1
+Α
? ? ? ? ? ? ? ? ?
+ Α2
? ? ? ? ? ? ? ? ?
+¼
Of course, for Lie's trick we need only the linear term. We can figure it out with the help of the following diagram :
r+Dr Α
Dr r
Fig. 12.1 Figure for thinking about the derivative matrix Q¢ BΑ È nF, evaluated at Α = 0. Axis n (not shown) has unit length, and rises out of the page at the center of the circle. Vectors r and r + Dr also have unit length.
As Dr shrinks to zero, it becomes perpendicular to n, and therefore parallel to n r . (We have the sign right: If you curl your right hand fingers to push n toward r, your thumb points in the direction of Dr.) Also, the length of Dr approaches the length of the little arc between r and r + Dr. By definition, angle Α is that little arc length divided by 2 Π. Now n r has unit length, so the limit of Dr is given by Α n r. Put all this into the definition of the derivative: JQB0 È nF.rN = LimB ¢
Α®0
Q@ΑD.r-Q@0D.r Α-0
F = LimB Α®0
Α nr Α
F = nr
The prime can be moved onto the Q only, because r is independent of Α. This deserves a box: Q¢ B0 È nF.r = n r
(12.1) 153
Symmetry Theory
Q¢ B0 È nF.r = n r Cross products may always be written as the Dot product of an antisymmetric matrix and a vector. Taking the unit axis of rotation to be n = 8nx , ny , nz < and r = 8x, y, z<, the identity is
0 -nz ny nz 0 -nx .8x, y, z< 8nx , ny , nz < 8x, y, z< -ny nx 0 True
If we rewrite Eq. 12.1 in this format, Q¢ B0 È nF.r =
0
-nz
nz -ny
0 nx
ny -nx .r 0
the value of Q ¢ @0D is suddenly staring us in the face. It is Q B0 È nF = ¢
0 -nz ny nz 0 -nx -ny nx 0
Now we can write the series expansion of QBΑ È nF about Α = 0 correct to first order in Α. It is Q BΑ È nF = ¢
1 0 0 0 1 0 0 0 1
+
0 -nz ny nz 0 -nx -ny nx 0
Α+¼
We are confident that the matrices generated by this series form a group. Therefore, the first order term must perform Lie's trick; namely, QBΑ È nF == MatrixExpB
0 -nz ny nz 0 -nx -ny nx 0
ΑF
(12.2)
This is evaluated in Subsection 12.4.3, below.
(12.1) 154
Lie group fo 3D rotation
12.4.2 Simple cases: rotations about coordinate axes Before charging ahead, make sure this is consistent with what we already know. When 8nx , ny , nz < = 80, 0, 1< we have the important special case of rotation about the z axis. Then 0 -1 0 QBΑ È zF = MatrixExpB 1 0 0 0 0 0
ΑF;
% MatrixForm Cos@ΑD -Sin@ΑD 0 Sin@ΑD Cos@ΑD 0 0 0 1
This, of course, is the usual rotation matrix for rotation about the z axis. Astonishing. That MatrixExp really works. On your own Do the same thing for the x and y axes. These “generator matrices” play such an important role in group theory that we have made them callable from the Symmetry` package as Ix, Iy, and Iz. The I stands for InfinitesimalRotation. Other people call them Rx, Ry, and Rz; but really, they are not rotation matrices; they are infinitesimal rotation matrices. Map@GridForm, 8Ix, Iy, Iz
:
0 0 0
0 0 1
0 -1 0
,
0 0 -1
0 0 0
1 0 0
,
0 1 0
-1 0 0
0 0 0
>
12.4.3 The general axis-angle rotation matrix Formula 12.2 (click here) evaluates symbolically. Enforcing the unit length on n, it yields a formula for a 3-D rotation matrix that is not any worse than the Euler angle formula : LieRotMat1 =
155
Symmetry Theory
MatrixExpB
0 -nz ny nz 0 -nx -ny nx 0
ΑF . :nx 2 + ny 2 + nz 2 ® 1,
-nx 2 - ny 2 - nz 2 ® ä> ComplexExpand
99n2x + Cos@ΑD n2y + Cos@ΑD n2z , nx ny - Cos@ΑD nx ny - Sin@ΑD nz , Sin@ΑD ny + nx nz - Cos@ΑD nx nz =,
9nx ny - Cos@ΑD nx ny + Sin@ΑD nz , Cos@ΑD n2x + n2y + Cos@ΑD n2z , -Sin@ΑD nx + ny nz - Cos@ΑD ny nz =,
9-Sin@ΑD ny + nx nz - Cos@ΑD nx nz ,
Sin@ΑD nx + ny nz - Cos@ΑD ny nz , Cos@ΑD n2x + Cos@ΑD n2y + n2z ==
Abbreviating the trig functions as (Cos[Α] ® C and Sin[Α] ® S) and using Collect to bring together the coefficients of nx , ny , and nz , LieRotMat2 = LieRotMat1 . 8Cos@ΑD ® C, Sin@ΑD ® S< Collect@ð, 8nx , ny , nz
H1 - CL nx ny - S nz
n2x + C n2y + C n2z
H1 - CL nx ny + S nz
C
n2x
+
n2y
+C
S ny + H1 - CL nx nz -S nx + H1 - CL ny nz
n2z
S nx + H1 - CL ny nz
H1 - CL nx nz
-S ny +
C n2x + C n2y + n2z
A human can trim the diagonal terms a little more: n2a + C n2b + C n2c == n2a + C In2b + n2c M ==
n2a + C I1 - n2a M == n2a + C - C n2a == C + H1 - CL n2a
leaving
LieRotMat = 9
9C + H1 - CL n2x ,
H1 - CL nx ny - nz S, H1 - CL nx nz + ny S=,
9H1 - CL nx ny + nz S, C + H1 - CL n2y ,
H1 - CL ny nz - nx S=,
9H1 - CL nx nz - ny S, H1 - CL ny nz + nx S,
C + H1 - CL n2z ==;
12.4.4 Lie's matrix in tensor notation The better to appreciate its symmetry, separate LieRotMat into isotropic, symmetric, and antisymmetric parts :
C
156
1 0 0 0 1 0 0 0 1
+ H1 - CL
n2x
nx ny
nx nz
nx ny
n2y
ny nz
nx nz
ny nz
n2z
+S
0
- nz
ny
nz - ny
0 nx
- nx 0
Lie group fo 3D rotation
C
1 0 0 0 1 0 0 0 1
+ H1 - CL
n2x
nx ny
nx nz
nx ny
n2y
ny nz
nx nz
ny nz
n2z
+S
0
- nz
ny
nz - ny
0 nx
- nx 0
Note the cyclic symmetry in the off-diagonal terms. In tensor notation this is ∆Εformula = C ∆i,j + H1 - CL ni nj - S Εi,j,k nk ;
Let's check this. Mathematica does not automatically understand the Einstein convention, so in the last term we must do an explicit sum over repeated index k. We can sum over {1,2,3}, but not over {x,y,z}; so we must convert 8nx , ny , nz < to 8n1 , n2 , n3 <, and then back again when the sum is done. Also, we have to teach Mathematica about the alternating tensor Εi,j,k and the Kronecker delta function ∆i,j . It actually knows them, but not in the familiar notation. Call up ?LeviCivitaEpsilon and ?KroneckerDelta to see. You can use subscripts as the arguments of functions, but only if you are careful not to declare that all subscripted quantities are symbols. We often make that declaration in the preliminaries, but in this chapter we did not. Head@x0 D
Subscript
If that returned Symbol instead of Subscript, the following will not work. You must quit Mathematica and start this chapter in a fresh session. Εi_,j_,k_ := LeviCivitaEpsilon@i, j, kD Now we are ready for Mathematica to evaluate ∆Εformula: ∆Εresult = TableBC ∆i,j + H1 - CL ni nj - S â Εi,j,k nk , 3
k=1
8i, 1, 3<, 8j, 1, 3
It checks; the ∆Εformula is correct.
12.5 The operator AxialRotation[axis, angle] The 3-D Lie rotation matrix is in the Symmetry` package as AxialRota tion. Use the ? to call up its syntax statement.
157
Symmetry Theory
On your own Check all three types of input. Make a vector with Random[] Cartesian components, calculate its length, set the length equal to Α, and then test all three types of input. In Chapter 13 (RecognizeMatrix) we will construct an inverse for the function AxialRotation. It will be named RecognizeMatrix, and it will find the axis and rotation angle for any given rotation matrix, among other things.
12.5.1 Check the handedness; boring but necessary You can never be too careful about handedness. Here is a small rotation of {1,0,0} about the z axis, using a positive angle of 0.1 Radian : AxialRotation@80, 0, 1<, 0.1D.81, 0, 0<
80.995004, 0.0998334, 0.<
Is this a right-handed rotation? Look toward the origin from a +Z position, with +X rightward and +Y upward. When your right thumb points over your left shoulder (in the +Z direction), the fingers curl up and left. Therefore the tip of the +X vector, rotated through a small positive angle, should move up and left. In the x direction the point moved from 1 to .995 (left), and in the y direction it moved from 0 to 0.099 (up). So all is well. Just permute the symbols and you have it for another case.
12.5.2 The {1,1,1} axis example In Chapter 11 we saw how difficult it is to use Euler angles to describe a rotation by 1/3 turn about the diagonal of the unit cube. Remember, this is the rotation that permutes the axes (x®y, y®z, z®x). Now it is easy. The desired axis is {1,1,1} and the angle is 2Π/3 : AxialRotation@81, 1, 1<, 2 Π 3D
880, 0, 1<, 81, 0, 0<, 80, 1, 0<<
The answer is just a permutation matrix, serving as a rotation matrix.
158
End Notes
12.6 End notes 12.6.1 The Collect operator Watch it work:
Collect@a x + b y - c x - d y, 8x, y
12.6.2 Symmetric word substitution We define a ZaxisStatement in the little closed cell below. It was originally defined in an Input cell, with a String in Text style as the right side of the Set statement, but when it is Saved, Mathematica converts it to a horrible unreadable format, so don't look at it. But do evaluate it; the return is perfectly legible. Look toward the origin from a +Z position,with +X rightward and +Y upward. When your right thumb points over your left shoulder Hin the +Z directionL, the fingers curl up and left. Therefore the tip of the +X vector, when rotated through a small positive angle, should move up and left.
Take the ZaxisStatement and permute the axes: XaxisStatement = StringReplace@ ZaxisStatement, 8"X" ® "Y", "Y" ® "Z", "Z" ® "X"
YaxisStatement = StringReplace@ XaxisStatement, 8"X" ® "Y", "Y" ® "Z", "Z" ® "X"
159
Symmetry Theory
Lots of books say “just permute the symbols and you have it for another case”. This is the first book that really does it.
12.6.3 Translation group solution (a) The group proof is just examination of the four axioms. Closure: Two matrices of this pattern yield a third one of the same pattern under Dot K
1 Α 1 Β O.K O 0 1 0 1
881, Α + Β<, 80, 1<<
The unit axiom and the inverse axiom are easily satisfied: unitMatrix == K
1 Α O . Α ® 0 0 1
unitMatrix 881, 0<, 80, 1<<
invMatrix == K
1 Α O . Α ® -Α 0 1
invMatrix 881, -Α<, 80, 1<<
K
1 Α 1 -Α O.K O 0 1 0 1
881, 0<, 80, 1<<
(b) The series expansion happens to terminate exactly after two terms. It is K
1 Α 1 0 0 Α O=K O+K O 0 1 0 1 0 0
The linear term performs Lie's trick : MatrixExpBK K
0 Α OF MatrixForm 0 0
1 Α O 0 1
(c) The matrices of the counter-example do not form a group. K
1 Sin@ΑD 1 Sin@ΒD O.K O MatrixForm 0 1 0 1
K
1 Sin@ΑD + Sin@ΒD O 0 1
No way is Sin[Α]+Sin[Β]identical for all Α,Β to Sin[someFn[Α,Β]]. So the matrix pattern is not preserved under Dot. These matrices do not close, do not form a group, and do not perform Lie's trick. 160
End Notes
So the matrix pattern is not preserved under Dot. These matrices do not close, do not form a group, and do not perform Lie's trick. SeriesBK
1 Sin@ΑD O, 8Α, 0, 1
1 Α + O@ΑD2 0 1
If you try to make it do Lie's trick, it produces the translation group formula. On your own (a)
To verify the commutation rubric above, put the matrix factors in
different multiplication orders and recalculate. (b) Calculate to second differential order, retaining mixed differentials of total order 2, and note that multiplication order already matters.
On your own Prove this by direct calculation on three general 3´3 matrices.
On your own Replace DotComm by Dot in the Outer operator that produces the commutation table above. You will see that Dot produces nothing of great interest; neither a group, nor anything else recognizable. Only the commutators produce something suggestive.
161
13. Recognizing matrices Preliminaries
13.1 The problem, and a strategy 13.1.1 Rotational eigensystem theorem Rotation matrices and rotoreflection matrices, in numerical form, usually have no distinguishing characteristic identifiable by inspection. Unless they are especially simple, they look just about like any other 3-by-3 real numerical matrix filled with values between -1 and +1. In this chapter we develop numerical tests to distinguish them, and to extract the axis and the angle. These tests are collected together in a useful operator named RecognizeMatrix, based on the following theorem : Rotational eigensystem theorem If an axis is given by the unit vector {a,b,c} and an angle by Α , Then the matrix for the specified rotation has eigenvectors given by the rows of the matrix
evecRows =
2
a
b
c
-b2 -c2
a b-ä c
ä b+a c
b2 +c2 -b2 -c2
2
b2 +c2
2
b2 +c2
a b+ä c 2
b2 +c2
2
b2 +c2
-ä b+a c 2
b2 +c2
with corresponding eigenvalues 91, ã+ä Α , ã-ä Α = . Comment: Notice that the rotation angle Α does not appear anywhere in the eigenvectors, nor does the axis appear in the eigenvalues. How clean!
13.1.2 Proof We want the rotation matrix for a rotation axis of unit length. So here is a rule enforcing normalization: W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_13, © Springer Science+Business Media, LLC 2009
163
Symmetry Theory
unitAxis = :a2 ® 1 - b2 - c2 , -a2 ® -1 + b2 + c2 , u_ a2 + b2 + c2
-u_
® u,
+
a2
b2
® -u>; +
c2
and here is the rotation matrix :
Rotmat = AxialRotation@8a, b, c<, ΑD . unitAxis; Rotmat MatrixForm Size@7D
1 - b2 - c2 + Ib2 + c2 M Cos@ΑD a b H1 - Cos@ΑDL - c Sin@ΑD a c H1 - Cos@ΑDL + b Sin@ΑD a b H1 - Cos@ΑDL + c Sin@ΑD a c H1 - Cos@ΑDL - b Sin@ΑD
b2 + I1 - b2 M Cos@ΑD
b c H1 - Cos@ΑDL - a Sin@ΑD
b c H1 - Cos@ΑDL + a Sin@ΑD c2 + I1 - c2 M Cos@ΑD
Eigensystem can calculate the eigenvectors of this matrix symbolically, but the expressions returned are extremely long. (Try it; you will be appalled. It takes less than two seconds at 1 GHz , or 30 seconds at 60 MHz.) We could do this and then prove the theorem by dragging you through a tedious simplification process, but that would be too boring. Instead, we will prove it by eigensystem diagonalization, as discussed in the MatrixReview. The idea is that for any given matrix, there are just a few matrices which diagonalize it by the formula evecsÖ.Rotmat.evecs = diagMat Matrix evecs is unique up to a rearrangement of its columns, which are the eigenvectors of Rotmat. No other columns can possibly produce a diagonal matrix on the right side. The adjoint of evecs is the conjugate of evecRows, as given in the theorem statement :
evecsÖ =
a
b
c
-b2 -c2
a b-ä c
ä b+a c
b2 +c2
2
-b2 -c2
b2 +c2
2
2
b2 +c2
-ä b+a c
a b+ä c
b2 +c2
2
b2 +c2
2
2
b2 +c2
so that evecs itself is -b2 -c2
a 2
evecs =
b
2
c
b2 +c2
a b+ä c b2 +c2
-ä b+a c 2
b2 +c2
-b2 -c2 2
b2 +c2
a b-ä c 2
;
b2 +c2
ä b+a c 2
Verify orthonormality of these vectors :
b2 +c2
HevecsÖ.evecs SimplifyL . unitAxis
164
;
Problem and strategy 881, 0, 0<, 80, 1, 0<, 80, 0, 1<<
Now for the proof that they are the eigenvectors of Rotmat. We test whether Rotmat is diagonalized by a similarity transform between evecs† on the left and evecs on the right: HevecsÖ.Rotmat.evecs SimplifyL . unitAxis Simplify TrigToExp; % MatrixForm 1 0
0
0 ãä Α 0 0 0
ã-ä Α
That's it; q.e.d. The given vectors have to be the eigenvectors because no other vectors can perform this diagonalization. Furthermore, the diagonal elements above and the columns of evecs must be in corresponding order. On your own Redo this proof (by Copy and Paste, with minimal alteration) for the general rotoreflection matrix. You might need just one hint: The real eigenvalue will be -1 . If you have trouble getting started, click here. We now have everything we need to extract the axis and the angle from a numerical rotation matrix.
13.2 Recognize a numerical rotation matrix Make a rotation matrix with input numbers that are easy to remember. It is important to this discussion that we use a negative input angle : rotMatN = AxialRotation@81., 2., 3.<, -2 Π 5D; rotMatN MatrixForm 0.358373 0.861253 -0.360293 -0.66383 0.506441 0.550316 0.656429 0.041955 0.75322
Pretending that we know only the matrix itself, we find its Eigensystem :
165
Symmetry Theory
8evalsN, evecsN< = ChopInteger@Eigensystem@rotMatNDD; Size@7D@evalsND Size@7D@Column@evecsNDD
81, 0.309017 + 0.951057 ä, 0.309017 - 0.951057 ä<
80.267261, 0.534522, 0.801784< 80.681385, -0.104828 + 0.588348 ä, -0.157243 - 0.392232 ä< 80.681385, -0.104828 - 0.588348 ä, -0.157243 + 0.392232 ä<
Check that the eigensystem operator did its job : evecsNT = Transpose@evecsND; rotMatN.evecsNT == evecsNT. DiagonalMatrix@evalsND True
Pair up each eigenvalue with its own eigenvector : epairs = Transpose@8evalsN, evecsN
81, 80.267261, 0.534522, 0.801784<<
80.309017 + 0.951057 ä, 80.681385, -0.104828 + 0.588348 ä, -0.157243 - 0.392232 ä<< 80.309017 - 0.951057 ä, 80.681385, -0.104828 - 0.588348 ä, -0.157243 + 0.392232 ä<<
As predicted in the theorem statement, we have two complex eigenvalues conjugate to each other, and another eigenvalue equal to 1. Preparing for automation of this process, we use the Cases operator to pull out the case in which eval is 1 : 8eval1 , evec1 < = Cases@ Transpose@8evalsN, evecsN
Check the basic eigenvector property : rotMatN.evec1
80.267261, 0.534522, 0.801784<
The vector did not change. The only points that stay put under a rotational transform are those that lie on the axis of rotation. We have recovered the axis of rotation, up to a multiplicative constant. In fact, it is normalized :
166
Recognize rotation
axis = evec1 ; axis.axis 1.
Is this the axis that we used as input? It will be more familiar if we scale it so that its first element equal to 1 : axis axisP1T 81., 2., 3.<
Indeed, there are the simple numbers we used as axis input. Now for the rotation angle. We know the eigenvalues are of the form Exp[± ä Α], so we Select for the presence of a Complex number : complexEvals = Select@evalsN, Not@FreeQ@ð, ComplexDD &D 80.309017 + 0.951057 ä, 0.309017 - 0.951057 ä<
The theorem says these numbers should be 9ã+ä Α , ã-ä Α = .
The angles
themselves are found by
angles = Π HArg@complexEvalsD Π RationalizeL :
2Π 5
,-
2Π 5
>
Note that we divided by Π before rationalizing, and then re-multiplied afterwards. So the rotation angle is 2Π/5, with an unavoidable ambiguity in sign. This is linked to an unavoidable ambiguity in the sign of the rotation axis. On your own : Verify that the axis-angle pair {{a,b,c},Α} produces exactly the same rotation matrix as {{-a,-b,-c},-Α}. We must settle this ambiguity by adopting a convention. Here it is : The rotation angle is chosen as a positive acute angle (a number in [0,Π]). We feed this angle and the rotation axis to AxialRotation. If the output agrees with the input matrix, we are done. If not, the sign of the axis is changed, and agreement is then assured. The input angle was actually -2 Π/5 ; but we “ do not know” this. Try to reconstruct the input matrix using a positive angle : AxialRotation@axis, 2 Π 5D == rotMatN
167
Symmetry Theory
False
The only possible error is that we chose the wrong sign for the angle (as we know we did). To compensate, we change the sign of the axis and recompute : AxialRotation@-axis, 2 Π 5D == rotMatN
True
We can automate this check as part of the operator. The angle will always be positive, and the axis will always come out with the right sign.
13.3 Recognize a rotoreflection matrix The proof for rotoreflection goes just like the proof for rotation, above, with only a few changes in details. It would be an excellent exercise for you to make a copy of that section and run it, making modifications as they are needed. If you run into trouble, click here.
13.4 Recognize a reflection matrix Reflection matrices are just rotoreflection matrices with zero rotation angle. Use ?AxialReflection to see the syntax statement. inputAxis = RandomReal@80, 1<, 3D 80.414379, 0.0268549, 0.98056<
Refmat = AxialReflection@inputAxisD 880.697141, -0.0196275, -0.716665<, 8-0.0196275, 0.998728, -0.0464453<, 8-0.716665, -0.0464453, -0.695869<<
8evals, evecs< = Eigensystem@RefmatD ChopInteger 881, -1, 1<, 880.270397, -0.958718, -0.0880115<, 8-0.389139, -0.0252191, -0.920834<, 80.921179, -0.0106535, -0.388993<<<
As you would expect by setting Α to zero in the rototreflection result, the key feature of the eigensystem of a reflection matrix is the eigenvalue set X1,1,-1\. But the position of the -1 eigenvalue is not dependable, so you must Sort before doing an automated comparison. 168
13.5 Operator RecognizeMatrix
RecognizeMatrix operator
13.5 Operator RecognizeMatrix The process of recognizing symmetry transform matrices is so simple that it really does not need a human to carry it through. So we have made an operator called RecognizeMatrix, which carries out the whole process quickly and accurately. Its syntax statement is RecognizeMatrix[mat(,prcsn)] is a function inverse to the three Axial… operators. The return is {matrixType,fold Number,{axis,angle}}. The foldNumber is 2Π/angle. Returned angles are always positive, and rotations are right handed as viewed from the returned axis point. Optional parameter prcsn is the number of digits used for comparison, with default 12. If mat is not a numerical symmetry transform matrix, the return will be "anomalous".
It begins by testing for matrix size (3 ´3), reality, and unitarity . Failure here leads to immediate rejection. Then it finds the eigensystem of the given matrix, and examines the eigenvalues. First it looks for the special cases of identity matrix {1,1,1} and inversion matrix {-1,-1,-1} and reports just the names if it finds them. Next it tests whether the matrix is a reflection, by looking for the eigenvalue set {-1,1,1}. If it finds this it reports “reflection”, along with the reflection axis (the eigenvector that goes with -1). If not, it goes on to the cases of nonzero angle, and reports as described in the thumbnail sketch, above. If you want to see exactly how all this is done, open up the Symmetry` package and have a look. It is a lengthy case analysis based on If, Goto, and Label, just as in any computer language. On your own (a) Try a few examples, just to see it work. You will see many more examples in the chapters ahead. (b) Make a rotation matrix and add 10-6 to one of its elements. It will be slightly non-unitary (no longer a true point group symmetry operation) and RecognizeMatrix ought to detect this and reject it.
169
Symmetry Theory
13.6 The complex eigenvectors Give the rotation axis a name, zeta : Ζ = 83., 2., 1.<;
Here we will finally investigate the meaning of the complex eigenvectors. Mrot = AxialRotationBΖ, 2 Π 7F; Mrot MatrixForm
0.865532 -0.0475917 0.498587 0.370315 0.731064 -0.573073 -0.337226 0.680647 0.650383
Find its Eigensystem :
8evalsN, evecRowsN< = Eigensystem@Mrot D ChopInteger; esysN = Transpose@8evalsN, evecRowsN
80.62349 + 0.781831 ä, 80.157243 + 0.392232 ä, 0.104828 - 0.588348 ä, -0.681385<< 80.62349 - 0.781831 ä, 80.157243 - 0.392232 ä, 0.104828 + 0.588348 ä, -0.681385<< 81, 8-0.801784, -0.534522, -0.267261<<
The two complex {eval,evec} pairs are conjugate to each other, and therefore contain the same information. We work with only one of them. 8evalComplex, evecComplex< = Cases@esysN, 8_Complex, 8_, _, _<
80.62349 + 0.781831 ä, 80.157243 + 0.392232 ä, 0.104828 - 0.588348 ä, -0.681385<<
The angle of rotation is Φ = Arg@evalComplexD 0.897598
Here is the trick: We split the complex eigenvector into its real and imaginary parts : 170
Complex eigenvectorsvecs
:Ξ, Η> =
8 Re@evecComplexD, Im@evecComplexD<
880.157243, 0.104828, -0.681385<, 80.392232, -0.588348, 0<<
Remember, we already set the axis of rotation equal to Ζ. We test the three vectors Ξ, Η,Ζ for orthogonality : :Ξ, Η, Ζ>.TransposeB:Ξ, Η, Ζ>F ChopInteger MatrixForm 0.5 0 0 0 0.5 0 0 0 14
They are orthogonal in x,y,z space. They are not normalized, but this is not important. The following profound equality shows how rotation can be expressed as a complex eigenequation . It is just the eigenvalue equation with Mrot is the operator, Ξ + ä Η is a complex eigenvector for it, and the corresponding complex eigenvalue Exp[ä Φ] .
Mrot .KΞ + ä ΗO == Exp@ä ΦD KΞ + ä ΗO
True
We look with new eyes, and reinterpret. On the left above, Ξ and Η are two real vectors in x,y,z space, perpendicular to each other and to the rotation axis Ζ . Matrix Mrot rotates each one by angle Φ about Ζ . On the right, Ξ + ä Η is a triple of complex numbers ( Ξ1 + ä Η1 , etc.) , which may be seen as points in the complex plane. Each of these points rotates in the complex plane by angle Φ when multiplied by Exp[ä Φ]. We are dealing with two different spaces here, and therefore two different kinds of “ rotation”. On the left, it is the rotation in three-dimensional xyz space. On the right, it is rotation in the complex plane. Incredibly clever, that Eigensys tem operator.
171
Symmetry Theory
13.7 End Notes 13.7.1 Explicit RotoReflection derivation In a rotoreflection, every point on the rotation axis is reflected through the origin. In symbols, RRMat.axis == (-1)*axis. This says that the axis vector is an eigenvector of the rotoreflection matrix, with eigenvalue -1. We proceed as before: RRMat = AxialRotoReflection@8a, b, c<, ΑD . a2 + b2 + c2 ® 1; RRMat MatrixForm Size@7D
-a2 + I1 - a2 M Cos@ΑD
-a b H1 + Cos@ΑDL - c Sin@ΑD -a c H1 + Cos@ΑDL + b Sin@ΑD
-a b H1 + Cos@ΑDL + c Sin@ΑD -b2 + I1 - b2 M Cos@ΑD
-b c H1 + Cos@ΑDL - a Sin@ΑD
-a c H1 + Cos@ΑDL - b Sin@ΑD -b c H1 + Cos@ΑDL + a Sin@ΑD -c2 + I1 - c2 M Cos@ΑD
Find the symbolic Eigensystem :
8time, 8evalsRR, evecsRR<< = Eigensystem@RRMatD Timing; time 0.857566
The vectors are horrifying; don't even look. Look instead at the eigenvalues : IevalsRR . 9 -a2 ® -1 + b2 + c2 = ExpandAllM . -u_2 ® ä u TrigToExp
9-1, ã-ä Α , ãä Α =
This time the real eigenvalue is -1, and the angle appears as before. Make a numerical rotoreflection matrix with input parameters that are easy to remember. rotMatN = AxialRotoReflection@81., 2., 3.<, -2 Π 5D; rotMatN MatrixForm 0.215516 0.575539 -0.788865 -0.949544 -0.0649879 -0.306827 0.227857 -0.815188 -0.532494
The rest of the derivation is the same as for the reflection matrix.
172
14. Introduction to the character table Preliminaries
14.1 Introduction This chapter is full of unproved results; in fact, it is an advertisement for many theorems about groups that lie just ahead. By describing the character table at this point we give can perhaps rouse a little curiosity about these theorems. We provide forward links to them as we go; if you are reading this chapter as review the links should prove especially useful. We cannot describe the character table without the new term representation and an adjective for it, irreducible. A representation of an abstract group is a list of concrete mathematical objects that multiply like the defining multiplication table of the abstract group. We will work mainly with matrix representations, but permutation representations also exist. For the formal definition in Chapter 25 (Representations), click here. Block diagonalization is a way of splitting a large representation into two or more smaller ones. But block diagonalization has a limit; eventually the blocks cannot be reduced any farther. Every group has a small number such representations, called irreducible representations. The main purpose of the character table is to give you key information about the irreducible representations. Irreducible representations are also called symmetry species; or just, species. Even more briefly, we sometimes just say rep. This is a very qualitative explanation of irreducibility, but it should serve to get us started. For the precise definition of irreducible in Chapter 28 (ReducibleReps), click here.
14.2 The standard character table In this book you can call up character tables in two ways; (1) as a typeset box, or (2) as a nested List structure. Here is the typeset version for group D2 d : BoxedCharacterTable@"D2d"D
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_14, © Springer Science+Business Media, LLC 2009
173
Symmetry Theory
D2d 1
2
1
2
2
E S4 C2 C¢2 Σd A1
1
1
1
A2
1
1
1
B1
1 -1
1
1
-1
B2
1 -1
1
-1
1
E
2
-2
0
0
0
1
1
-1 -1
¬ Class populations 8 x2 + y2 , z2 <
Basis functions 9 Ix2 - y2 M z , Iz=
:
8 x2 - y2 < 8 z , x y<
x x z Ix , , > y y z Iy
And here is its homely sister, the nested List structure (spruced up a bit by the Column wrapper): CharacterTable@"D2d"D; Size@8D@Column@%DD
81, 2, 1, 2, 2< 8E, S4 , C2 , C¢2 , Σd <
9A1 , 81, 1, 1, 1, 1<, 99x2 + y2 =, 9z2 ===
9A2 , 81, 1, 1, -1, -1<, 99Ix2 - y2 M z=, 8Iz<== 9B1 , 81, -1, 1, 1, -1<, 99x2 - y2 ===
8B2 , 81, -1, 1, -1, 1<, 88z<, 8x y<<< 8E, 82, 0, -2, 0, 0<, 88x, y<, 8x z, y z<, 8Ix, Iy<<<
It is not so pretty, but it is easier to lift parts from it. On your own If you want to see all the character tables in this book, just issue Map[BoxedCharacterTable,GroupCatalog]. Perhaps interactive readers should do so at this point. Then you can check the following description against any of the examples you like.
174
Some facts
14.3 Some facts about the character table 14.3.1 The essentials Taking D2 d as an example, the most essential parts of the character table are brought forth by SquareEssentials@"D2d"D D2d E S4 A1 A2 B1 B2 E
C2
C¢2
Σd
1 1 1 1 1 1 1 1 -1 -1 1 -1 1 1 -1 1 -1 1 -1 1 2 0 -2 0 0
We omit the broad right column, which is discussed below in its own Section. We now discuss several features visible in the SquareEssentials.
14.3.2 The columns As will be proved in Chapter 22 (Classes), all groups may be divided into nonoverlapping classes of elements. The class names appear at the head of the columns of the character table. The first class always consists of just one element, the identity element E , and it is always called class E. Continuing along the top row of this example, the second class is called S4 . The S in its name tells you that it consists only of rotoreflections; the third class is C2 , and the C in its name says that it consists only of rotations. Similarly for class C¢2 . The last class is Σd , and the Σ in its name tells you it consists of reflections.
14.3.3 The rows There is one row for each irreducible representation that the group possesses. The names appear down the left column of the table. The first four rows are numerical representations (1 ´1 matrices), but the E row is a 2 ´2 representation. The full rationale behind the species names will be given in Chapter 28, but you may click here for a peek ahead if you just have to.
14.3.4 The body 175
Symmetry Theory
14.3.4 The body The tabulated quantity is the “character” of the representation matrices. The character of a class is the trace, or Spur, or diagonal sum of matrix members. Spur is a Afrikaans word meaning footprint or scent. It will be proved that in every representation of a group, all group elements in the same class have the same smell, or footprint. This is why the character belongs to a whole class. We demonstrate on rep T of group T . First, look at its SquareEssentials : SquareEssentials@"T"D T E A1 1
C3 1
Ea 1 - 12 -
ä
Eb 1 - 12 +
ä
T
3
C32 1 3 2 3 2
- 12 +
ä
- 12 -
ä
0
C2 1 3 2 3 2
1 1 -1
0
Construct rep T with an operator MakeRepPoly[polyList,group] from Chapter 27 (MakeRep). You cannot possibly understand this operator yet, so don't worry about how it does its job. Just take it on faith that it returns a representation of the group that has some relation to the functions x, y, and z. xyzRepT = MakeRepPoly@8x, y, z<, "T"D; % MatrixList Size@6D 1 0 0 : 0 1 0 0 0 1
,
0 0 1 -1 0 0 0 -1 0
0 1 0 0 0 1 1 0 0
,
,
0 0 -1 -1 0 0 0 1 0
0 -1 0 0 0 1 -1 0 0
,
,
0 0 1 1 0 0 0 1 0
0 -1 0 0 0 -1 1 0 0
,
,
1 0 0 0 -1 0 0 0 -1
0 1 0 0 0 -1 -1 0 0
,
,
-1 0 0 0 1 0 0 0 -1
0 0 -1 1 0 0 0 -1 0
,
,
-1 0 0 0 -1 0 0 0 1
>
Given a bunch of matrices and a claim that they represent a group, you do know already how to test this claim: MultiplicationTable@xyzRep, Range@12DD == MultiplicationTable@CartRep@"T"D, Range@12DD True
Since the multiplication table for this bunch of matrices closes, and is identical to the multiplication table of the Cartesian symmetry operators of group ”T”, the claim is True. Now we invoke the Classify operator from Chapter 22 (Classes) to split the rep into classes. Again take it on faith that this is what it is doing.
176
Some facts
byClasses = Classify@xyzRepTD; Size@6D@Column@MatrixList %DD 1 0 0 : 0 1 0 > 0 0 1 -1 0 0 : 0 -1 0 , 0 0 1 0 -1 0 : 0 0 -1 , 1 0 0 0 0 -1 : -1 0 0 , 0 1 0
-1 0 0 0 1 0 0 0 -1 0 -1 0 0 0 1 -1 0 0 0 0 -1 1 0 0 0 -1 0
,
,
,
1 0 0 0 -1 0 0 0 -1 0 1 0 0 0 -1 -1 0 0 0 0 1 -1 0 0 0 -1 0
>
,
,
0 0 1 0 1 0
1 0 0 0 0 1
0 1 0 1 0 0
> >
There is one class on each row. The first class is class E, with trace 3. Then comes a class of three matrices, all having trace -1. (Add them up yourself!) Then comes a class of four, all having trace 0. The fourth class also has four elements with trace 0. The machine can do it too: Map@Spur, byClasses, 82
883<, 8-1, -1, -1<, 80, 0, 0, 0<, 80, 0, 0, 0<<
The trace is the same for each matrix in any given class, as advertised.
14.3.5 One-dimensional species Some species consist of 1´1 “matrices”; that is, just numbers. Their names are always anchored on an A or a B, and they are particularly easy to interpret. Look, for instance, at species A2 of group D2 d . An object of species A2 changes sign when transformed by any one of the C¢2 rotations, or any of the Σd reflections, but is unaltered by transforms from classes E , S4 , and C2 . This accounts for the entries {1,1,1,-1,-1} on row A2 . BoxedCharacterTable@"D2d"D D2d 1
2
1
2
2
E S4 C2 C¢2 Σd A1
1
1
1
A2
1
1
1
B1
1 -1
1
1
-1
B2
1 -1
1
-1
1
E
2
-2
0
0
0
1
1
-1 -1
¬ Class populations 8 x2 + y2 , z2 <
Basis functions 9 Ix2 - y2 M z , Iz=
:
8 x2 - y2 < 8 z , x y<
x x z Ix , , > y y z Iy
This table says that the polynomial Ix2 - y2 M z transforms like rep A2 . Verify:
177
Symmetry Theory
Ix2 - y2 M z . SymmetryRules@"D2d"D Ix2 - y2 M z
Simplify;
OnePerClass@%, "D2d"D 81, 1, 1, -1, -1<
Yes, this is the A2 row of the table.
14.3.6 The trivial representation The whole first row is always a one-dimensional species, with name anchor A. It is just a row of 1's, and it is called the “trivial” representation. Objects that “belong to” the first species are called totally symmetric objects, because all the transforms of the group simply multiply them by 1 (i.e., leave them unchanged.) Ground state wave functions are examples of totally symmetric objects.
14.3.7 Multi-dimensional species D2d 1
2
1
2
2
E S4 C2 C¢2 Σd A1
1
1
1
A2
1
1
1
B1
1 -1
1
1
-1
B2
1 -1
1
-1
1
E
2
-2
0
0
0
1
1
-1 -1
¬ Class populations 8 x2 + y2 , z2 <
Basis functions 9 Ix2 - y2 M z , Iz= 8 x2 - y2 < 8 z , x y< x x z Ix : , , > y y z Iy
Look now at species E, the last row. In the standard display above, each pair is presented as a column. So the pairs are {x and y}, {xz and yz}, and {Ix and Iy}. This is weird, I admit, but there is a reason for it. If you want them in a List, see the TabulatedBases operator below. The first thing to learn is that species E has nothing to do with class E. They have the same name due to an unfortunate historical accident, and we must live with it. The species anchor E indicates a two-dimensional representation (or sometimes, two complex conjugate one-dimensional representations). These reps are always based on two functions that transform into a linear combination of themselves, and you need the full rep matrix to see exactly how. Nevertheless, the character is meaningful and useful. Click below for a little more detail. Other groups have even larger multi-dimensional representations; the anchors of their names are T , F, G, or H, with dimensions, respectively, of 3, 3, 4, and 5. These all occur in the icosahedral group “I” : 178
Some facts
Other groups have even larger multi-dimensional representations; the anchors of These all occur in the icosahedral group “I” : BoxedCharacterTable@"I"D I
1
12
12
20 15
A
E 1
C5 1
C52 1
C3 C2 1 1
T1 3
F2 3
1 2
1 2
+
-
5
1
2
2
5
1
2
2
-
+
5 2
5 2
0
-1
0
-1
¬ Class populations Basis functions 8 x2 + y2 + z2 < x Ix : y , Iy > z Iz 3 x2 y - y3 + 6 x y z : x3 - 3 x y2 - 3 x2 z + 3 y2 z > 3 x2 z + 3 y2 z - 2 z3
G
4
-1
-1
1
0
:
2 x3 y + 2 x y3 + 3 x2 y z - y3 z - 12 x y z2 x4 - y4 - x3 z + 3 x y2 z - 6 x2 z2 + 6 y2 z2 x4 - 6 x2 y2 + y4 + 3 x3 z + 3 x y2 z - 4 x z3 3
3
2
3
>
3
I-x2 - y2 + 2 z2 M
4x y-4xy -3x yz-3y z+4yz 1
H
5
0
0
-1
1
:
2 1 2
Ix2 - y2 M 3
>
xy yz xz
If related functions were presented as rows, this table would be way too long to fit on the page.
14.3.8 The species dimension number Since class E has only one member, the unit matrix, its character is the sum of n 1's, where n is the dimension of the representation. Obviously, the dimension of any species may be read as the character of its class E. The rep dimensions in our tabulated groups, as it happens, can be any integer from 1 to 5.
14.3.9 The table is square In every group, the number of classes is equal to the number of species, so the essential inner part of every character table is square. This is not a quick or easy theorem. It will come as part of Chapter 33 (TheGreatOrthogonality).
179
Symmetry Theory
14.4 The rightmost column; bases for reps The broad rightmost column contains information needed for constructing the irreducible representations. They are easily found by the use of projection operators, but many standard books present character tables that have lots of blanks in this column. Take this as proof that projection operators have a high barrier in work by hand. But because our MakeRep operators can use these basis sets explicitly, in this book every species has at least one tabulated basis set. The number of basis functions is the dimension of the species. For many species, several alternate sets of basis functions are given. If only one is given, it is in double braces to conform to the requirement that it be a List of Lists. You can extract all the basis information in usable format with TabulatedBases@"D2d"D; Size@7D@Column@%DD
9A1 , 99x2 + y2 =, 9z2 ===
9A2 , 99Ix2 - y2 M z=, 8Iz<== 9B1 , 99x2 - y2 ===
8B2 , 88z<, 8x y<<< 8E, 88x, y<, 8x z, y z<, 8Ix, Iy<<<
or you can extract (for instance) just the A1 basis information with TabulatedBases@"D2d"DP1, 2T 99x2 + y2 =, 9z2 ==
The basis information is always a List of Lists, though in one-dimensional species the inner list has only one member. 1) For species A1 we see function x2 + y2 given as a basis, because it always transforms into itself under the operations of the group. Similarly, so does the second listed basis function, z2 . Ix2 + y2 M . SymmetryRules@"D2d"D Ix2 + y2 M
Simplify
81, 1, 1, 1, 1, 1, 1, 1<
Try the other one-dimensional species yourself. 2) For species E the basis functions come in pairs, because they transform into linear combinations of themselves. Here is a particularly simple example : 180
Rep basis functions
linear combinations of themselves. Here is a particularly simple example : 8x, y< . SymmetryRules@"D2d"D
88x, y<, 8y, -x<, 8-y, x<, 8-x, -y<, 8-x, y<, 8x, -y<, 8y, x<, 8-y, -x<<
14.5 Various character table operators You have already seen BoxedCharacterTable and CharacterTable. Other character table operators bring down named parts of the table. $DefaultGroup = "C3v"; ClassPopulations@D 81, 2, 3<
ClassNames@D 8E, C3, Σv<
ElementNames@D
8E, C3a, C3b, Σva, Σvb, Σvc<
Classes@D
88E<, 8C3a, C3b<, 8Σva, Σvb, Σvc<<
SpeciesNames@D 8A1, A2, E<
Column@TabulatedBases@DD 9A1, 98z<, 9x2 + y2 =, 9z2 === 8A2, 88Iz<<<
:E, :8x, y<, : 1 Ix2 - y2 M, x y>, 8x z, y z<, 8Ix, Iy<>> 2
On your own Change the $DefaultGroup at the top, and run them all again. These are the basic facts about character tables. In the following chapters you will see them proved rigorously.
181
15. The operator MakeGroup Preliminaries
15.1 An operator for constructing groups The group generation procedure suggested previously in Chapter 07 (FundamentalThm) is so simple and logical that we ought to be able to automate it. We describe here the construction of an operator that will carry out the whole group construction procedure with a single ó. We call it MakeGroup[elList], where elList will be a short list of group elements (usually, one, two, or three of them). The elements may be either matrices or permutations. This operator returns the entire group implied by the short list. We first give two short demonstrations of the operator : First we let MakeGroup make a group of matrices. Start with just one matrix, Cz @2 Π 3D: gp1 = MakeGroup@8Cz @2 Π 3D
- 12 3 2
0
3
-
2
,
-1
0
-
0
1
0
2
3
- 12
0
2 3 2
0 ,
-1
0
0
1
2
1 0 0 0 1 0 > 0 0 1
From that one matrix, MakeGroup generated a list of three matrices. Are they a group? After Chapter 13, where we constructed the RecognizeMatrix operator, we are all set up to answer this : Map@RecognizeMatrix, gp1D Column
:rotation, 3-fold, :80, 0, 1<,
2Π >> 3
:rotation, 3-fold, :80, 0, -1<, 8identity<
2Π >> 3
Yes, this is group C3 , the group of rotations by ±1/3 turn. Now we let Make Group make a permutation group. Start with one permutation of length 4 : perms4 = MakeGroup@882, 4, 1, 3<
881, 2, 3, 4<, 82, 4, 1, 3<, 83, 1, 4, 2<, 84, 3, 2, 1<<
Is this list of permutations a group? The only axioms in question are closure and inverse elements, so the quickest test is just to make a multiplication table : W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_15, © Springer Science+Business Media, LLC 2009
183
Symmetry Theory
and inverse elements, so the quickest test is just to make a multiplication table : MultiplicationTable@ Permute, perms4, 8"E", b, c, d
b d E c
c E d b
d c b E
It closes, and every element has an inverse, so perms4 is a group. The Make Group operator also has a verbose mode. Watch it operate on two permutations of length 6 : MakeGroup@882, 3, 4, 1, 5, 6<, 82, 3, 4, 1, 6, 5<< , Report ® TrueD
881, 2, 3, 4, 5, 6<, 81, 2, 3, 4, 6, 5<, 82, 3, 4, 1, 5, 6<, 82, 3, 4, 1, 6, 5<, 83, 4, 1, 2, 5, 6<, 83, 4, 1, 2, 6, 5<, 84, 1, 2, 3, 5, 6<, 84, 1, 2, 3, 6, 5<<
It cycled until the number of elements stopped increasing.
15.2 MakeGroup, step by step Now we show how MakeGroup was constructed. As always, the first job is to carry out an example by hand. So we start with two matrices : step1 = 8Cz @2 Π 4D, Cx @2 Π 2D <; % MatrixList Size@6D
0 -1 0 : 1 0 0 0 0 1
,
1 0 0 0 -1 0 0 0 -1
>
In Chapter 08 (MultiplicatnTbls) we used Outer, operating at level 1 : step2 = Outer@Dot, step1, step1, 1D; % MatrixForm Size@6D -1 0 0 0 -1 0
0 -1 0 -1 0 0
0 0 1 0 0 -1
0 1 0 1 0 0
1 0 0 0 1 0
0 0 -1 0 0 1
As you see, Outer has organized its output as a matrix of matrices, containing all possible two-matrix products, A.A, A.B, B.A, and B.B . But we need them in as a List of matrices, so we apply Flatten at level 1 : 184
MakeGroup operator
step3 = Flatten@step2, 1D; % MatrixList Size@6D -1 0 0 : 0 -1 0 0 0 1
,
0 1 0 1 0 0 0 0 -1
0 -1 0 -1 0 0 0 0 -1
,
>
1 0 0 0 1 0 0 0 1
,
Neither of the two original matrices is in the product list. We don't want to lose them, so we join them in : step4 = Join@step1, step3 D; % MatrixList Size@6D
0 -1 0 : 1 0 0 0 0 1
1 0 0 0 -1 0 0 0 -1
,
-1 0 0 0 -1 0 0 0 1
,
0 1 0 1 0 0 0 0 -1
,
,
0 -1 0 -1 0 0 0 0 -1
,
1 0 0 0 1 0 0 0 1
>
This is the end of the first cycle. We started with two matrices in step1 and now in step4 we have six matrices. If we run the step4 matrices through the same cycle of operations, we will learn something new. The operations in steps 5, 6 and 7 are the same as in steps 2, 3, and 4 : step5 = Outer@Dot, step4, step4, 1D; step6 = Flatten@step5, 1D; step7 = Join@step6, step4D; % Dimensions 842, 3, 3<
Indeed, it made 42 matrices. This seems like too many. There must be repeats, and we need to winnow them out. The operator that does this is Union. Here is a simple demo : Union@8c, b, a, b, c
Applied to a single list with repeats in it, Union took out the repeats and put the remaining list in canonical order. (For a fuller picture of Union, call up its thumbnail description.) What happens if we use Union on our list of 42 matrices ? step8 = Union@step7D; % MatrixList Size@6D -1 0 0 : 0 -1 0 0 0 1 0 -1 0 1 0 0 0 0 1
,
,
-1 0 0 0 1 0 0 0 -1 0 1 0 -1 0 0 0 0 1
,
,
0 -1 0 -1 0 0 0 0 -1
0 1 0 1 0 0 0 0 -1
,
, 1 0 0 0 -1 0 0 0 -1
,
1 0 0 0 1 0 0 0 1
>
So the list of 42 contained just 8 different matrices. That's more like it. Note, however, that Union uses an ordering in which the unit matrix comes last. Look at the MultiplicationTable of these 8 matrices: 185
Symmetry Theory
MultiplicationTable@Dot, step8, 8"a", "b", "c", "d", "e", "f", "g", "E"
g E d c f e a b
f e E g b a d c
e f b a E g c d
d c g E a b f e
c d a b g E e f
b a e f c d E g
a b c d e f g E
It closes, so these eight matrices form a group. If we cycled them through steps 5, 6, 7, and 8 again, the output would repeat the input. So we now see how to construct the general MakeGroup operator: we must nest operations 5 through 8 to make a compound operator called OneMatCycle, and then run OneMat Cycle repeatedly until it produces two successive results that are the same. Clear@OneMatCycleD; OneMatCycle@Lst_D := Reverse@Union@ Join@Lst, Flatten@Outer@Dot, Lst, Lst, 1D, 1DDDD The innermost operation, in red, is Outer. Then in alternating red and black colors, Outer is wrapped with Flatten, Flatten is wrapped with Join, Join is wrapped with Union, and finally Union is wrapped with Reverse (which reverses list order, to make the unit matrix come first). This is the functional style of programming, so natural to Mathematica. First we apply OneMatCycle to the two matrices we called step1 : cycle1 = OneMatCycle@step1D; % MatrixList Size@6D 1 0 0 : 0 1 0 0 0 1
1 0 0 0 -1 0 0 0 -1
,
,
0 1 0 1 0 0 0 0 -1
,
0 -1 0 1 0 0 0 0 1
,
0 -1 0 -1 0 0 0 0 -1
,
Two matrices made six, just as before. Cycle it again : cycle2 = OneMatCycle@cycle1D; % MatrixList Size@6D 1 0 0 : 0 1 0 0 0 1 0 -1 0 1 0 0 0 0 1
1 0 0 0 -1 0 0 0 -1
,
,
,
0 -1 0 -1 0 0 0 0 -1
0 1 0 1 0 0 0 0 -1
,
,
-1 0 0 0 1 0 0 0 -1
0 1 0 -1 0 0 0 0 1
,
,
-1 0 0 0 -1 0 0 0 1
>
Six matrices made eight, as before. Once more: cycle3 = OneMatCycle@cycle2D; % MatrixList Size@6D
186
-1 0 0 0 -1 0 0 0 1
>
MakeGroup operator
1 0 0 : 0 1 0 0 0 1 0 -1 0 1 0 0 0 0 1
1 0 0 0 -1 0 0 0 -1
,
,
,
0 -1 0 -1 0 0 0 0 -1
0 1 0 1 0 0 0 0 -1
,
,
-1 0 0 0 1 0 0 0 -1
0 1 0 -1 0 0 0 0 1
,
,
-1 0 0 0 -1 0 0 0 1
>
Eight matrices made the same eight again, and we surely have a group. Now we can carry the automation to its final stage. We want to call OneMatCycle on a short list of group elements, and keep applying it to its own output until it starts repeating itself. If we use the While construction, we can do this without knowing the number of times OneMatCycle is to be used. The While operator requires a little external setup: Clear@ListA, ListBD; ListA = 8<; ListB = step1; Remember, step1 is our original list of two matrices. We will use While : While@test, bodyD evaluates test, then body, repetitively, until test first fails to give True.
Below, the test is Length[ListA]=!=Length[ListB] (where =!= means is not equal to ) and the body is all the rest. H*Loop entrance*L While@Length@ListAD =!= Length@ListBD, H*old answer becomes new input:*L ListA = ListB; H*generate next answer:*L ListB = OneMatCycle@ListAD; Print@Length@ListAD, " mats made ", Length@ListBD, " mats"D; H* go back up and apply the test; exit if false*L H*endWhile*L D
2 mats made 6 mats 6 mats made 8 mats 8 mats made 8 mats
ListB MatrixList Size@6D
187
Symmetry Theory
1 0 0 : 0 1 0 0 0 1 0 -1 0 1 0 0 0 0 1
1 0 0 0 -1 0 0 0 -1
,
,
,
0 -1 0 -1 0 0 0 0 -1
0 1 0 1 0 0 0 0 -1
,
,
-1 0 0 0 1 0 0 0 -1
0 1 0 -1 0 0 0 0 1
,
,
-1 0 0 0 -1 0 0 0 1
>
It looks like it worked. On your own Copy the operator OneMatCycle and turn it into OnePermCycle, making a permutation group rather than a matrix group. A single word change accomplishes this. Then use it on a short list of permutations until you have a closed permutation group. A good starting point is PermList1 = 882, 3, 4, 1, 5, 6<, 82, 3, 4, 1, 6, 5<< ; In three cycles, this makes a group of eight permutations. If you get tangled up, click to the End Notes. In the Symmetry` package operator MakeGroup, we have constructed a test that distinguishes matrix input from permutation input, and uses either Dot or Permute, as appropriate. So it can make either matrix groups of permutation groups. Open up the package to read the details. It also politely declines invalid input: MakeGroup@881, 2, 3<, 84, 5<
Input is neither matrix list nor permutation list
The rest of this chapter is devoted to some tricky programming issues, only tangentially relevant to Symmetry Theory. Some people may want to stop here and go on to Chapter 16.
188
Roundoff
15.3 MakeGroup with roundoff 15.3.1 The problem The operator above worked beautifully with infinite precision input. However, often we will have matrices of Real numbers, known only to machine accuracy, and an ugly little issue raises its head. When you compute the same Real matrix by two different routes, you may get two answers that differ insignificantly in the last one or two digits of some of the elements (on a Macintosh, in digits 15 and 16). If you use the Equal operator ( == ) to ask whether the two matrices are equal, Mathematica will normally say True, because it reports equality if the two sides are equal to within machine roundoff error. However, we must apply Union to eliminate duplicates. Unfortunately, Union has a little quirk that prevents it from working quite the way we want. First, we do an example using exact elements, just to show the answer expected. Applying OneMatCycle twice, Map@MatrixForm, OneMatCycle@OneMatCycle@8Cz @2 Π 3D
0
1
3
2
2 3 2
0
1
-
0 ,
1 2 3
0
2
2
1
0
3
-
0
2 1
>
0
2
0
1
It worked; that is the three-member cyclic group C3 . Now we demonstrate the undesirable quirk using the approximate rotation angle 2Π/3. (with a decimal point behind the 3) instead of the exact angle 2Π/3 (with no decimal point). We get a different answer : Map@MatrixForm, OneMatCycle@OneMatCycle@8Cz @2 Π 3.D
-0.5 -0.866025 0 0.866025 -0.5 0 , 0 0 1
-0.5 -0.866025 0 0.866025 -0.5 0 , 0 0 1
-0.5 0.866025 0 -0.866025 -0.5 0 > 0 0 1
We get four matrices, not three. The last three seem to be identical. Clearly, Union has failed to do the desired job.
15.3.2 The fix, part 1: A homemade Union operator
189
Symmetry Theory
15.3.2 The fix, part 1: A homemade Union operator How does Union really work? Here we make up a homemade Union operator that takes a list of symbols as input, returning a sorted list, with repeats removed, as its output. Let the example input be the list {a,b,b,c,b,d}. sorted = Sort@8a, b, b, c, b, d
Now we partition the sorted list into pairs, with an offset of 1. This changes a list into a list of pairs, each pair consisting of an element and its successor. pairedWithSuccessors = Partition@sorted, 2, 1D 88a, b<, 8b, b<, 8b, b<, 8b, c<, 8c, d<<
Now we Select from this list of pairs only pairs that are not self-pairs. This eliminates the repeats. The comparison function for Select is neq@8a_, b_
Now Transpose produces two lists, each one being almost what we want. However, the last element is missing from the first list, and the first element is missing from the second list. twoLists = Transpose@differentPairsD 88a, b, c<, 8b, c, d<<
We patch this up by prepending the first element of the first list onto the second list. Prepend@twoLists@@2DD, twoLists@@1, 1DDD 8a, b, c, d<
This is the desired output, constructed by a perfectly general method. We have cleverly written the comparison function neq so that it works on either symbols or matrices, even on matrices of arbitrary size. We test it on two matrices that are close, but not precisely equal : Ε = 1. * 10-16 ;
190
Roundoff
twoCloseMats = :K
1-Ε 3 1 3 O, K O>; 2 4 2 4
Map@MatrixForm, %D
:K
1. 3 1 3 O, K O> 2 4 2 4
neq@twoCloseMatsD False
So it is False that they are NotEqual; or in other words, it is True that their difference is zero, within the criterion used by the Chop operator.
15.3.3 RoundSort, an improved Sort for matrices The homemade Union operator above uses the built-in Sort operator, and this leads to a second independent difficulty. When sorting matrices or other compound objects, Sort begins sorting on the first element of the first row, element P1,1T. If there is a tie in this element, it breaks the tie using the second element of the first row, element P1,2T, etc. Thus we see SortB:K :K
1 3 1 2 O, K O>F Map@MatrixForm, ðD & 2 4 3 4
1 2 1 3 O, K O> 3 4 2 4
But suppose the list includes a matrix similar to K
1 3 O but with its P1,1T 2 4 element insignificantly smaller than 1. Then there is no tie on element P1,1T, and we get a different, and possibly undesired, sorted order : Ε = 1. * 10-16 ; 1-Ε 3 1 3 1 2 SortB:K O, K O, K O>F 2 4 2 4 3 4 Map@MatrixForm, ðD &
:K
1. 3 1 2 1 3 O, K O, K O> 2 4 3 4 2 4
The first and third matrices ought to have been neighbors in sorted order because they differ only insignificantly. Instead, Sort seized on the tiny defect in 1-Ε to list this matrix as the first matrix. Clearly, we need a different kind of Sort operator that does a little rounding before it sorts, so that insignificant numerical differences in corresponding elements are ignored. We have written such an operator and stored it in the Symmetry` package. It is called Round Sort : 191
Symmetry Theory
RoundSort@list,HsigfigsLD rounds the list to sigfigs significant figures, then sorts the rounded list and returns the original unrounded list in sorted order. The default for sigfigs is 12. Use it for sorting matrices when you want to ignore numerical dither.
RoundSortB:K
1-Ε 3 1 3 1 2 O, K O, K O>F 2 4 2 4 3 4
Map@MatrixForm, ðD &
:K
1 2 1. 3 1 3 O, K O, K O> 3 4 2 4 2 4
With RoundSort we can be sure that matrices that differ only insignificantly will always appear as neighbors in the sorted order. This is a prerequisite for our homemade RoundUnion operator to work correctly. RoundUnion@list,HsigfigsLD does the same thing as Union@listD, except that the elements of the list are rounded to the specified number of sigfigs Hdefault 12L before the Union operation is performed. It is used mainly to ignore numerical dither in lists of matrices.
RoundUnionB:K
1-Ε 3 1 3 1 2 O, K O, K O>F 2 4 2 4 3 4
Map@MatrixForm, ðD &
:K
1 2 1. 3 O, K O> 3 4 2 4
15.3.4 The total fix: procedure MakeGroup Now we show how to construct group C3 using Real matrices. We begin by applying OneMatCycle twice to the matrix Cz @2 Π 3.D : approxMats = OneMatCycle@OneMatCycle@8Cz @2 Π 3.D
9991., 6.10623 ´ 10-16 , 0.=, 9-6.10623 ´ 10-16 , 1., 0.=, 80., 0., 1.<=, 88-0.5, -0.866025, 0.<, 80.866025, -0.5, 0.<, 80., 0., 1.<<, 88-0.5, -0.866025, 0<, 80.866025, -0.5, 0<, 80, 0, 1<<, 88-0.5, 0.866025, 0.<, 8-0.866025, -0.5, 0.<, 80., 0., 1.<<=
That is group C3 , but without removal of near-equal matrices. In MakeGroup, there is a limit of 200 matrices to prevent runaway operation when the group does not close. The next step is to RoundSort to ensure that similar matrices appear as neighbors : (To see the actual outputs below, read this chapter in interactive mode on a computer) 192
That is group C3 , but without removal of near-equal matrices. In MakeGroup, Roundoff there is a limit of 200 matrices to prevent runaway operation when the group appear as neighbors : (To see the actual outputs below, read this chapter in interactive mode on a computer) listRS = RoundSort@approxMatsD; Each matrix is paired with its successor : dbls = Partition@listRS, 2, 1D; and Union is implemented by retaining only pairs that are not equal : difs = Select@dbls, neqD; Finally, the successor-pairs are unpaired, and one complete sequence is constructed : Prepend@Transpose@difsDP2T, difsP1, 1TD ChopInteger Map@MatrixForm, ðD & Size@7D
-0.5 -0.866025 0 0 , : 0.866025 -0.5 0 0 1
-0.5 0.866025 0 -0.866025 -0.5 0 , 0 0 1
1 0 0 0 1 0 > 0 0 1
There is a group of Real matrices, with insignificant roundoff errors handled appropriately. This procedure is kept in the Symmetry` package as part of the operator MakeGroup. See the text of the Round operators in the package.
15.4 End notes 15.4.1 OnePermCycle for permutations We want to make a permutation group, starting with the short list
PermList1 = 882, 3, 4, 1, 5, 6<, 82, 3, 4, 1, 6, 5<< ;
We will multiply everything by everything, adding all new results to the growing list of elements, until we reach closure. The operator is Clear@OnePermCycleD; OnePermCycle@Lst_D := Reverse@Union@Join@Lst, Flatten@Outer@Permute, Lst, Lst, 1D, 1D DDD where all we did was change Dot to that blue Permute. Let it do its job : PermList2 = OnePermCycle@PermList1D 883, 4, 1, 2, 6, 5<, 83, 4, 1, 2, 5, 6<, 82, 3, 4, 1, 6, 5<, 82, 3, 4, 1, 5, 6<<
PermList3 = OnePermCycle@PermList2D 193
Symmetry Theory 884, 1, 2, 3, 6, 5<, 84, 1, 2, 3, 5, 6<, 83, 4, 1, 2, 6, 5<, 83, 4, 1, 2, 5, 6<, 82, 3, 4, 1, 6, 5<, 82, 3, 4, 1, 5, 6<, 81, 2, 3, 4, 6, 5<, 81, 2, 3, 4, 5, 6<<
PermList4 = OnePermCycle@PermList3D
884, 1, 2, 3, 6, 5<, 84, 1, 2, 3, 5, 6<, 83, 4, 1, 2, 6, 5<, 83, 4, 1, 2, 5, 6<, 82, 3, 4, 1, 6, 5<, 82, 3, 4, 1, 5, 6<, 81, 2, 3, 4, 6, 5<, 81, 2, 3, 4, 5, 6<<
PermList3 == PermList4 True
It closed, so the group is complete.
194
16. Product groups Preliminaries
16.1 An introductory example (group C3 h ) Multiplication to closure is not the only way to construct groups. In this chapter we show how one can sometimes combine two groups already known to make a new, larger group. We begin with an example. Look at the tabulated Cartesian matrices that represent groups C3 and Ch : CartRep@"Ch"D MatrixList Size@7D
1 0 0 : 0 1 0 , 0 0 1
1 0 0 0 1 0 > 0 0 -1
1 0 0 : 0 1 0 , 0 0 1
-
CartRep@"C3"D MatrixList Size@7D 1
3
-
2 3
-
2
0
-
0
2
,
1
-
0
2
0
1
1
3
2
2 3
-
2
0
1
0
>
0
2
0
1
Take the Outer product of Ch with C3 and Flatten appropriately. So far, the operator Ä has been a merely symbolic multiplication of individual group elements, but now we extend its meaning to products of whole groups. In the preliminaries we define MatListProduct[A, B] to be a Flattened Outer product using Dot, with Ä as its “ infix alias”. The Outer product was used in Chapter 8 (MultiplicationTbls). This means you may call MatList Product[A, B] as A Ä B. ChxC3 = CartRep@"Ch"D
Ä CartRep@"C3"D;
% MatrixList Size@5D 1 0 0 : 0 1 0 , 0 0 1
-
1
3
-
-
0
2
2
1
3
2
2
0
, 3
-
2 0
1
0
, -
2 0
3
-
2 1
0
1
0
1 0 0 , 0 1 0 0 0 -1
-
-
0 2
1
3
2
2
0
, 3
-
2 1
3
-
2
2 0
1
0
1
0
-
2 0
3
-
2 -1
0
1
>
0
2 0
-1
The result is a list of 6 matrices. The first three are just C3 again; the second three are similar, but with a -1 in the lower right. Is this group C3 h ? ChxC3 == CartRep@"C3h"D True
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_16, © Springer Science+Business Media, LLC 2009
of the 195 The = 2´
Symmetry Theory
Yes. So group C3 h is the direct product of Ch and C3 . The order of the product group is the product of the orders of the two parent groups. The structure of the Outer operator ensures that this is generally true. (Here 6 = 2 ´ 3.)
16.2 The product group theorem Research mathematicians do not state theorems and then prove them. Instead, they start with a curious observation based on a concrete calculation. They do more calculations to uncover the origin of the curious behavior, and slowly a proof begins to emerge. When they finally have a general proof, then, as a last step, they state the theorem. When they write the textbook, they leave out the curious observation and the hard work of exploring blind alleys. They just state the theorem, and then give the proof, leaving the impression that God sent it to them in a dream. Eschewing this convention, we present the Product Group Theorem in a little more realistic way. We begin with the curious observation that the outer product of Ch and C3 is group C3 h . Can every pair of groups make a product group? More precisely, given a group A = {A1 ,A2 ,… ,Am } and another group B = {B1 ,B2 ,… ,Bn }, is it always true that the set of all ordered products Am Ä Bn is also a group? We begin by examining the four axioms. Take the easy ones first : Axiom 2: (Unit element) Both groups contain E, so E Ä E = E will be present. Axiom 4: (Associativity) A and B are groups under Ä, so Ä is associative. Axiom 1: (Closure) If the group consists only of products like Am Ä Bn , then the product HAm Ä Bn L Ä HAr Ä Bs L is by closure necessarily equal to some At Ä Bu . But by associativity the product may be rewritten without parentheses as Am Ä Bn Ä Ar Ä Bs . Then if we can switch Bn and Ar we can rewrite the product asHAm Ä Ar L Ä HBn Ä Bs L. Now Am Ä Ar will be some At , and Bn Ä Bs will be some Bu , and the product would be of the required form, At Ä Bu . So the closure axiom would be satisfied. But the switch of Bn and Ar is not generally valid, and the answer to the question, as originally stated, must be no. But we can turn it into a yes by imposing the requirement that all the elements of A and B must commute. This must be 196 stated prominently in the theorem, when we get to it. But there is one more axiom to check first.
Theorem
But the switch of Bn and Ar is not generally valid, and the answer to the question, as originally stated, must be no. But we can turn it into a yes by imposing the requirement that all the elements of A and B must commute. This must be stated prominently in the theorem, when we get to it. But there is one more axiom to check first. Axiom 3: (Inverse) Group A contains Ai and Ai-1 , and group B contains Bk and B-1 k , so for every Ai Ä Bk in the product, there is also a product Ai-1 Ä B-1 k . If they are mutually inverse, they will yield the unit element when multiplied in either order, and the inverse axiom will be satisfied : HAi Ä Bk L Ä Ai-1 Ä B-1 k
and IAi-1 Ä B-1 k M Ä HAi Ä Bk L will be E.
There is no reason to think this is true as it stands. But we have already found that the two groups must commute, so we can reverse the second product in each expression; -1 HAi Ä Bk L Ä B-1 k Ä Ai
and then
-1 Ai Ä IBk Ä B-1 k M Ä Ai
or IAi-1 Ä B-1 k M Ä HBk Ä Ai L
or
Ai-1 Ä IB-1 k Ä Bk M Ä Ai
Taking innermost first, both expressions multiply to an E, so all four axioms are satisfied. Now, finally we know what the theorem should be : If A is a group and B is a group , and if every element of A commutes with every element of B then A Ä B is a group.
16.3 How to recognize product groups The character tables of groups are arranged to help you spot product groups. For instance, look at BoxedCharacterTable@"C3h"D
197
Symmetry Theory
C3h 1
1
1
1
C32 Σh 1 1
1
1
S3 1
S35 1 Ε*
A¢
E C3 1 1
E¢a
1
Ε
Ε*
1
Ε
E¢b
1
Ε*
Ε
1
Ε*
Ε
A¢¢ E¢¢ a
1 1
1 Ε
1 -1 Ε * -1
-1 -Ε
-1 -Ε *
E¢¢ b
1
Ε*
Ε
-1 -Ε *
¬ Class populations Note : Ε = Exp@- 2 Π ä 3D Basis functions 8 x2 + y2 , z2 , Iz< 8x+äy< 8x-äy<
8z< 8 Hx + ä yL z < 8 Hx - ä yL z <
-Ε
There are an even number of classes, and the upper left quadrant of the table looks like the character table of group C3 . The first class in the right half is Σh, suggesting that the group is Ch Ä C3 . Also, the class names in the right half are plausibly Σh times the class names in the left half. But the ultimate test is CartRep@"Ch"D
Ä CartRep@"C3"D == CartRep@"C3h"D
True
That clinches it. We did not even have to Sort to get a match. You can apply these ideas to any character table to spot product groups.
16.4 Products with Ch vs. products with Ci The Cnh and Dnh groups contains a small surprise when n is even. We demonstrate using a Dnh group: BoxedCharacterTable@"D4h"D D4h 1
2
1
2
2
1
2
1
2
2
E C4 C2 C¢2 C¢¢ 2 inv S4 Σh Σv Σd A1g 1 1 1 1 1 1 1 1 1 1 A2g 1
1
1
-1 -1
1
1
1
-1 -1
B1g 1 -1
1
1
-1
1
-1
1
1
-1
B2g 1 -1
1
-1
1
1
-1
1
-1
1
0
-2
0
0
2
0
-2
0
0
2
A1u 1
1
1
1
1
-1
-1 -1 -1 -1 -1 -1 1 1 -1 -1
1 1
Eg
A2u 1 1 B1u 1 -1
1 1
-1 -1 1 -1
-1 -1
B2u 1 -1
1
-1
1
-1
1
-1
1
-1
-2
0
0
-2
0
2
0
0
Eu
2
0
¬ Class populations Basis functions 8 x2 + y2 , z2 <
9 x y Ix2 - y2 M , Iz= 8 x2 - y2 < 8xy<
:
x z Ix , > y z Iy
9 x y Ix2 - y2 M z = 8z< 8xyz <
9 Ix2 - y2 M z = :
x > y
By the ideas in the last section, it looks like D4 h is Ci Ä D4 . Test it: 198
Ch Ä Ci
By the ideas in the last section, it looks like D4 h is Ci Ä D4 . Test it: CartRep@"Ci"D
Ä CartRep@"D4"D == CartRep@"D4h"D
True
This same group can also be constructed as Ch Ä D4 , but you have to Sort to match them up : SortACartRep@"Ch"D
Ä CartRep@"D4"DE ==
Sort@CartRep@"D4h"DD True
On your own Repeat all the above using a C4 instead of D4 . Actually, it is true for any group Cn , with n even. Try it with C6 . Also in the Platonic groups, both Ci Ä T and Ch Ä T give Th , both Ci Ä O and Ch Ä O give Oh , and both Ci Ä I and Ch Ä I give Ih . On your own The first two, for groups T and O are quite easy to prove, with the aid of our tables and operators. Do it. The third one, for group I, is not so easy. The statement is true, but only if the icosahedron is in the right orientation. To see the details, click here, or look in the End Notes of this chapter. My guess is that Schoenflies himself constructed all these group as Ch Ä Cn or as Ch Ä Dn because he named them Cnh or Dnh . But all modern tables are remarkably consistent in ordering the even-n groups as Ci Ä Cn or Ci Ä Dn . Historians of mathematics, why is this? Do all modern tables trace back to a single post-Schoenflies author who for some reason preferred Ci over Ch ?
199
Symmetry Theory
16.5 Some careful checking, and a scandal 16.5.1 Product groups with Ci and Ch If the product group theorem is the governing authority for making product groups, we should be able to show that Imat from Ci and Σh from Ch commute with every matrix. a b c : d e f .Imat , g h i -a -b -c : -d -e -f , -g -h -i
Imat.
a b c d e f > MatrixList Size@7D g h i
-a -b -c -d -e -f > -g -h -i
So Imat is a universal commuter, and group Ci can make a product group with any other group. Surely, you may think, the same thing will be true for Σh . Try it: a b c : d e f .Σh , g h i a b -c : d e -f , g h -i
Σh .
a b c d e f > MatrixList Size@7D g h i
a b c d e f > -g -h -i
This is a shock. Matrix Σh is not a universal commuter! How can we get away with using it to make product groups, in violation of the theorem? It just happens to work in the cases where we use it, because it is used only with groups Cn and Dn , and they have a special matrix pattern that does commute with Σh . It is a b 0 : d e 0 .Σh , 0 0 i a b 0 : d e 0 , 0 0 -i
Σh .
a b 0 d e 0 > MatrixList Size@7D 0 0 i
a b 0 d e 0 > 0 0 -i
For the truly shocking scandal, read on.
200
Scandal
16.5.2 Product groups with Cv The Cnv groups with odd n are not product groups, but those with even n are indeed product groups and are tabulated as Cv Ä Cn . Group Cv is 8Emat, Σy < so you might assume that matrix Σy commutes with all rotations. But in group theory, never assume. Look at this: a b 0 : d e 0 .Σy , 0 0 i a -b 0 : d -e 0 , 0 0 i
Σy .
a b 0 d e 0 > MatrixList Size@7D 0 0 i
a b 0 -d -e 0 > 0 0 i
This is not commutation, and there is no commonly seen matrix pattern that makes it OK anyway. So why can we construct product groups with it? It is because of a variant of the product group theorem, which uses pseudocommuters. Look at the way Σy commutes with rotation matrices: Cos@ΑD -Sin@ΑD 0 Sin@ΑD Cos@ΑD 0 .Σy === 0 0 1
Σy .
Cos@ΑD -Sin@ΑD 0 Sin@ΑD Cos@ΑD 0 0 0 1
False
But we can turn this False into a True with a little trick; just negate the trigonometric angle when you swap the multiplication order : Cos@ΑD -Sin@ΑD 0 Sin@ΑD Cos@ΑD 0 .Σy === 0 0 1
Σy .
Cos@-ΑD -Sin@-ΑD 0 Sin@-ΑD Cos@-ΑD 0 0 0 1
True
This is what we mean by pseudo-commutation. It is not true commutation, but it is close enough that we do not abandon the word altogether. The product group proof for pseudocommuters is a great deal like that for commuters; so similar, in fact, that we relegate it to the End Notes, where it may be ignored by the many. But if you are one of the few, click here. The theorem it leads to is this: If A is a group and B is a group , and if A is such that A[-n Α] is the inverse of A[+n Α], and if A@n ΑD Ä Bu == Bu Ä A@-n ΑD then the outer product A Ä B is a group. Actually, Cv Ä Dn is an alternate construction for Dnh . 201
Symmetry Theory
Actually, Cv Ä Dn is an alternate construction for Dnh . SortACartRep@"Cv"D
Ä CartRep@"D6"DE ==
Sort@CartRep@"D6h"DD True
But don't try to call this group D6 v . Our Great Father Schönflies did not use Dn,v at all, and no one will know what you are talking about.
16.6 End notes 16.6.1 Construction of Schönemann's I and Ih (numerical) Group I may be generated by two rotations, one about the z axis and one in the zx plane at angle Α to the z axis, where the Sin and Cos of Α are 8cosΑ, sinΑ< = :
2
1 ,
5+
5
10
J5 +
5 N >;
One axis must be a twofold and the other a fivefold. The standard convention says to make the z axis fivefold. However, the matrices generated this way do not make a product group with group Ch . To see the product group you must make the z axis twofold. This is similar to the irregular choice for group T, in which z is a also twofold axis, ignoring the threefold axis on the diagonal of the enclosing cube. Group I is easily generated from two rotation matrices, in either the nonstandard Schönemann orientation (z is a twofold axis), or in standard orientation (z is a fivefold axis). Below we do it in Schönemann orientation. For standard orientation, just interchange the axes. The big difference is that Σh is a symmetry operation for the icosahedron in Schönemann's orientation, but not in standard orientation. matA = AxialRotation@80, 0, 1<, ΠD N; MatrixForm@%D -1. 0. 0. 0. -1. 0. 0. 0. 1.
matB = AxialRotation@8-sinΑ, 0, cosΑ<, 2 Π 5D N; MatrixForm@%D
202
End Notes
0.809017 -0.5 -0.309017 0.5 0.309017 0.809017 -0.309017 -0.809017 0.5
Then group I in Schönemann's orientation is given by groupI = MakeGroup@8matA, matB<, Report ® TrueD; Dimensions@groupID 860, 3, 3<
The next step is even quicker:
groupIh = ICartRep@"Ch"D
Ä groupIM RoundSort
;
Ä groupIM RoundSort
;
Dimensions@groupIhD 8120, 3, 3<
groupIi = ICartRep@"Ci"D Dimensions@groupIiD 8120, 3, 3<
Is groupIh the same as groupIi ?
HgroupIh - groupIiL Chop Union 8880, 0, 0<, 80, 0, 0<, 80, 0, 0<<<
Is it a group? We need to check only for closure. This takes a few seconds. mtIh = MultiplicationTable@Dot, groupIh, Range@120DD; % Dimensions 8120, 120<
The table is the right size, but were there any unrecognized products? FreeQ@mtIh, "?"D True
So using Schönemann's orientation for I the multiplication table is free of question marks. If I is generated in standard position, the table is mostly question marks.
203
Symmetry Theory
16.6.2 Pseudocommutation theorem for Cv Ä Cn The product group theorem can also be proved under the assumption that group A is the rotation group Cn and group B is the vertical reflection group Cv given by 8Emat, Σx <. The elements of group A (namely, Cn ) are constructed by the formula A@m_ , n_D := RotationMatrix3Dz@2 Π m nD
as m runs from 0 to n-1. Lemma Prove: Matrix A[-m,n] is in group Cn , even though it is not used explicitly in the group construction. The proof is simple. If A[m,n] is present by construction in group Cn , it has a unique inverse that is also present somewhere in the group. But A[m,n] has only one inverse, and it is returned by A[-m,n]: A@m, nD.A@-m, nD TrigExpand
881, 0, 0<, 80, 1, 0<, 80, 0, 1<<
so A[-m,n] is present in the group. Main theorem Now prove that the matrices generated by Cn Ä Cv form a group. We do only the hard parts: Axiom 1 (Closure) for pseudocommutation: If all products of the form A@m, nD Ä Bq form a group, then the product IA@r, nD Ä Bq M ÄHA@s, nD Ä Bt L is by closure necessarily equal to some A@u, nD Ä Bv . parentheses as
But by associativity the product may be rewritten without A@r, nD Ä Bq Ä A@s, nD Ä Bt . Then if Bq Ä A@s, nD is
identical to A[-s,n]Ä Bq we can rewrite the product as A@r, nD Ä A@-s, nD Ä Bq Ä Bt .
Now HA@r, nD Ä A@-s, nDL will be some A@u, nD, and Bq Ä Bs will be some Bv , so the product will be of the required form A@u, nD Ä Bv .
Axiom 3 (Inverse axiom) for pseudocommutation: Group A contains A@m, nD and its inverse A@-m, nD, and group B contains Bj and B-1 j , so for every A@m, nD Ä Bj in the product group, there is also a
product A@m, nD Ä B-1 j . The product of these two products may be taken two 204 ways: IA@m, nD Ä Bj M Ä A@m, nD Ä B-1 j
Axiom 3 (Inverse axiom) for pseudocommutation: Notes Group A contains A@m, nD and its inverse A@-m, nD, and group BEnd contains -1 Bj and Bj , so for every A@m, nD Ä Bj in the product group, there is also a product A@m, nD Ä B-1 j . The product of these two products may be taken two ways:
or
IA@m, nD Ä Bj M Ä A@m, nD Ä B-1 j A@m, nD ÄB-1 ÄIA@m, nD Ä Bj M . j
But we have already found the two groups must pseudo-commute, so we reverse and negate the angle of the second factor in each expression; IA@m, nD Ä Bj M Ä IB-1 j Ä A@- m, nDM A@m, nD ÄA@-m, nD == E or
A@m, nD ÄB-1 ÄIBj ÄA@-m, nDM A@m, nD ÄA@-m, nD == E j
Therefore, every element in the product group possesses an inverse, and the Inverse Axiom is satisfied. Now all four axioms are satisfied. As was to be proved, the matrices generated by Cn Ä Cv form a group. Click back to the main text to reread the statement.
205
17. Naming the point groups Preliminaries
17.1 Molecules and point groups In Chapter 11 (EulerRotations) and Chapter 12 (LieRotations) we studied the construction of individual rotation and rotoreflection matrices that are the elements of all point groups, and in Chapter 13 (RecognizeMatrix) we made operators that recognize the matrix types automatically, and in Chapter 14 (MakeMatrixGroup) we used them to generate whole groups. Now we are ready to understand the rationale behind the naming of the Point Groups. The point groups are all you need to analyze the symmetry of individual finite molecules, because molecules, like the point groups, also have a unique point, their center of mass. If a molecule has any symmetry, its center of mass will be the unique origin point where all its symmetry elements intersect. Therefore, all geometric symmetries of molecules are described by point groups. There are infinitely many point groups; indeed, there are infinitely many axial rotation groups alone. They may be sorted out and given systematic names in several different ways, each way based on the minimal lists of elements needed to generate the groups. This does not lead to a single unique best way to classify them and name them, because often a point group can be generated in several different ways. In the sections below, we study two different systems in common use, the Schönflies system (favored by chemists and spectroscopists) and the International system (favored by crystallographers and solid state physicists).
17.2 Schönflies names The first satisfactory naming system for point groups was proposed by the German mathematician Schönflies. He provided a name for each possible point group, proving exhaustively that he had left no point group unnamed. We omit his massive proof (see Bibliography). The names that Schönflies made up have taken root in chemistry, where the symmetries of molecules are invariably described by his names. Also, in molecular spectroscopy excited states are always named using the Schönflies names. His system is not unique or compellingly perfect, but it is not going to W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_17, © Springer Science+Business Media, LLC 2009
207
The names that Schönflies made up have taken root in chemistry, where the Symmetry Theory symmetries of molecules are invariably described by his names.
Also, in
names. His system is not unique or compellingly perfect, but it is not going to go away. It can be explained quite concisely. In every naming system for symmetry groups, one must first name the symmetry elements (the individual transform matrices). Here is the way Schönflies named them : Schönflies Name
Symmetry Element
E Hour EmatL i Hour ImatL
identity inversion
Cn C¢2
n - fold rotation axis 2 - fold rotation axis, perpendicular to a higher Cn axis
*
Σv
vertical mirror plane, containing the z and x axes
Σh
horizontal mirror plane, containing the x and y axes
Σd
n - fold rotoreflection axis Hthis name for even nL
**
Hn evenL
Sn Cnh
dihedral
*
Hn oddL
*
n - fold rotoreflection axis
Hthis name for odd n L
n - fold rotoinversion axis Hnot used in the Schönflies systemL
i. Cn
*
mirror plane
The Cn or Sn axis of highest order, called the “main” axis, defines the “vertical”.
**
Dihedral means vertical, bisecting the angles between Σv planes or C¢2 axes.
Once the symmetry elements are named, one may specify groups by giving short list of elements that generate the entire group. One then invents a name for the group by combining (in some attractive way) the names on the list. But there is no unique minimal list, so quite different names for the same group may arise in different naming systems. Schönflies followed a systematic plan for all groups based on a single n-fold axis, plus mirrors and perpendicular twofold axes. But when he got to groups related to the Platonic solids (tetrahedron, cube, octahedron, dodecahedron, and icosahedron), he made up special shorter names. Here is the way Schönflies picked the minimal list of generating elements, and the way that he collapsed the list of element names into a group name : Generating Elements i, the inversion Σv or Σh , the reflection
208
Schönflies Group Name Ci Cv or Ch
Sn axis, n even*
Sn Hn evenL
Cn axis Sn Hn oddL or HCn and Σh L
Cn Cn h
Cn Hn evenL, a Σv plane, and a Σd plane
Cnv
Cn Hn oddL and a Σv plane Cn axis and a ¦
C¢2
axis
Dn elements, and a Σh plane
Cnv Dn Dnh
Schönflies names
Generating Elements
Schönflies Group Name
i, the inversion Σv or Σh , the reflection
Ci Cv or Ch
Sn axis, n even*
Sn Hn evenL
Cn axis Sn Hn oddL or HCn and Σh L
Cn Cn h
Cn Hn evenL, a Σv plane, and a Σd plane
Cnv
Cn Hn oddL and a Σv plane
Dn
Dn elements, and a Σh plane
Dnh
H1L Dn elements and a Σd plane or H2L an S2 n axis and a Σd plane
Dnd
tetrahedron, rotations only cube or octohedron, rotations only dodecahedon or icosahedron, rotations only **
rotations of a tetrahedron, plus inversion all the symmetries of a tetrahedron
all the symmetries of a cube or octohedron all symmetries of a dodecahedron or icosahedron
* **
Cnv
Cn axis and a ¦ C¢2 axis
T O I or Y Th Td Oh Ih or Yh
Except that S2 is inversion, usually named as Ci The tetrahedron itself does not have this symmetry
In Chapter 18 (CartesianRepresentations) we will verify these names by using them to construct the groups.
17.3 International names 17.3.1 Rotoinversion There is a very fundamental difference between the Schönflies and International naming systems. Where the Schönflies system makes exclusive use of the rotoREFLECTION axis, the International system makes exclusive use of the roto-INVERSION axis. This is the root source of some confusion that we will try to clear up. We have shown that products of rotations and rotoreflections can never produce anything fundamentally new, but that word fundamentally betrays a small 209 difficulty. Let's bring it into the open. One can make a symmetry element called the rotoinversion by combining a rotation with an inversion. The rotoinversion about the z axis is given by
Symmetry Theory
We have shown that products of rotations and rotoreflections can never produce anything fundamentally new, but that word fundamentally betrays a small difficulty. Let's bring it into the open. One can make a symmetry element called the rotoinversion by combining a rotation with an inversion. The rotoinversion about the z axis is given by Clear@iCzD; iCz@Φ_D := Imat.Cz @ΦD; Look at z-axis rotoinversion (iCz) and rotoreflection ( Sz ) together : 8 iCz@ΦD, Sz @ΦD< MatrixList Size@7D
-Cos@ΦD Sin@ΦD 0 : -Sin@ΦD -Cos@ΦD 0 , 0 0 -1
Cos@ΦD -Sin@ΦD 0 Sin@ΦD Cos@ΦD 0 > 0 0 -1
Clearly they are different, but is the rotoinversion a “fundamentally” new kind of element? Not really. With a little thought, it is easy to see what it is : 8iCz@ΦD, Sz @Φ + ΠD< MatrixList Size@7D
-Cos@ΦD Sin@ΦD 0 : -Sin@ΦD -Cos@ΦD 0 , 0 0 -1
-Cos@ΦD Sin@ΦD 0 -Sin@ΦD -Cos@ΦD 0 > 0 0 -1
So rotoinversion about z by Φ is the same rotoreflection about z by Φ + Π . The isotropy of space assures us that this will be the same in any axial direction. But this kind of reasoning is a little too grand for some people, and we check it out directly for an arbitrary axis, {a,b,c}. Let iC be rotoinversion iC@Φ_D := AxialRotation@8a, b, c<, ΦD.Imat and let ΣC be rotoreflection : ΣC@Φ_D := AxialRotation@8a, b, c<, ΦD. AxialReflection@8a, b, c
As Mussolini used to say, “I think I may assert, without fear of contradiction, that …” Rotoinversion by Φ about any axis a is identical to rotoreflection about a by Φ + Π.
The table below summarizes this discussion. We just add another entry to a table you have seen before : 210
International names
a table you have seen before : Special Case General Case unit rotation@0D reflection rotoreflection@0D inversion rotoreflection@ΠD rotoinversion@ ΦD rotoreflection@ Φ + ΠD
17.3.2 International naming system The International system (or Hermann-Mauguin system) is very frugal in naming symmetry elements. There is no indication within the element name itself as to whether it is vertical, horizontal, or canted at some angle. An n-fold rotation axis is indicated by the integer n. With a bar over it, it indicates an nfold rotoinversion axis. A rotation with a perpendicular mirror is indicated as n n/m or . m
International Name .
Symmetry Element
n
n - fold rotation axis
n m
n - fold rotoinversion axis* mirror plane
n or n m m
n -fold rotation and ¦ mirror
* The
inversion bar, if it appears, always appears over the first rotation axis in the group name, making it into a rotoinversion axis. No group needs more than one rotoinversion axis, just as Schönflies never used more than one rotoreflection axis (S) in a group name. The group names in the International system are very subtle. The first axis named may be thought of as vertical. In the table below the “ m” is a literal m standing for “mirror”, but “ n” is an integer.
Generating Elements i, the inversion n - fold rotation axis n - fold rotoinversion axis n - fold vertical axis and a horizontal mirror* n - fold vertical rotation and a vertical mirror plan n - fold vertical rotation and two vertical mirrors n - fold rotation and a ¦ 2 - fold rotation
International Name 1 n n
n or n m m nm nmm n2 Hwith n > 2L
211
Symmetry Theory
International Name
Generating Elements i, the inversion n - fold rotation axis n - fold rotoinversion axis
1 n n
n or n m m nm nmm n2 Hwith n > 2L 23
n - fold vertical axis and a horizontal mirror* n - fold vertical rotation and a vertical mirror plan n - fold vertical rotation and two vertical mirrors n - fold rotation and a ¦ 2 - fold rotation vertical 2 - fold and canted 3 - fold *
two elements, NOT combined to make a single rotoreflection
17.4 Schönflies-International correspondences Usually these correspondences are important only when dealing with crystals. It may be proved that a 3D crystal cannot form if its unit cell has rotations or rotoreflections of order other than 1, 2, 3, 4, or 6. This excludes many groups; indeed, it excludes all but 32 of them, which are known as the “crystal point groups” Here they are, with Schönflies names on the red stripes and the Hermann-Mauguin (or International) names directly below on the blue stripes. CrystalPointGroupsTable triclinic monoclinic
C1
Ci
1
1
Ch m
C2 2
rhombic
C2 v D2 D2 h mm 222 mmm
trigonal
C3
S6
C3 v
D3
D3 h
3
3
3m
32
6m2
C4
S4
C4 h
C4 v
D2 d
4
4
4m
4mm 42m 422 4mmm
C6
C6 h
C6 v
6mm 622 6mmm
tetragonal
hexagonal D3 d C3 h cubic
212
C2 h 2m
3m
6
6
6m
T
Th
Td
O
Oh
23
m3
43m
432
m3m
D4 D6
D4 h D6 h
Correspondences
Fig. 17.1 Proposed flag for the International Crystallographic Union. Schönflies names are on the red background; the Hermann-Maugin names are on blue.
It may seem odd to you that D4 d and D6 d are missing. But take a look at the third symmetry elements from each of these groups: RecognizeMatrix@CartRep@"D4d"DP3TD :rotoreflection, 8-fold, :80, 0, -1<,
Π 4
>>
RecognizeMatrix@CartRep@"D6d"DP3TD :rotoreflection, 12-fold, :80, 0, -1<,
Π 6
>>
Because 8-fold and 12-fold rotoreflection axes cannot fit into a crystal lattice, these groups are excluded, in spite of their tempting Schönflies names. The International names begin with the axis of highest symmetry, so D4 d would start with 8 and D6 d would start with 12, making it obvious they could not be crystal groups. Maybe this is one reason that crystallographers like that system.
17.5 Some interesting name correspondences 17.5.1 Group names C2v and mm The CrystalPointGroupsTable says that C2v is the same as mm. This sounds a little odd, because the Schönflies name says it comes from a rotation and a reflection, whereas the International name says it comes from two perpendicular reflections. Let's make sure there is no contradiction. groupC2 v = MakeGroup@8Cz @2 Π 2D, Σx
All is well.
213
Symmetry Theory
17.5.2 Group names C6v and 6mm The Schönflies name C6v implies a vertical C6 axis and vertical mirror plane. Our orientation convention requires that it be Σx . groupC6 v = MakeGroup@8Cz @2 Π 6D, Σx
Map@RecognizeMatrix, groupC6 v D Sort Column
8identity< 8reflection, 80, 1, 0<< :reflection, : 12 , :reflection, : 1 ,
3 2 3
, 0>>
8reflection, 81, 0, 0<< 2
:reflection, : :reflection, :
3 2 3
2
, 0>>
, - 12 , 0>> 1 , 2
8rotation, 2-fold, 880, 0, 1<, Π<< 2
,
0>>
:rotation, 3-fold, :80, 0, -1<,
2Π >> 3
:rotation, 6-fold, :80, 0, -1<,
Π >> 3
:rotation, 3-fold, :80, 0, 1<,
2Π >> 3
:rotation, 6-fold, :80, 0, 1<,
Π >> 3
Now we can check that this is the same as 6mm; but wait- a vertical C6 axis and vertical mirror plane is 6m , which we just did above. The second m has to contain the 6-fold axis and be perpendicular to the first m, which means that it has to be Σy . Indeed, Σy (i.e., {reflection,{0,1,0}}) came out automatically as one of the group members, so we would get the same group if we included it in the original short list. But why do so? This is a mystery known only to the old International Commission, long since gone to its eternal reward. Obviously the name 6mm generates group C6v, so it is formally correct; but it could be shortened to 6m. Still, 6mm is official, and we stick with it.
17.5.3 Group names D2h and mmm The Schönflies name says this group is generated by a vertical C2, a perpendicular C2, and a Σh . We generate it : 214
Examples
Cz @ΠD
88-1, 0, 0<, 80, -1, 0<, 80, 0, 1<<
D2hCalc = MakeGroup@8Cz @ΠD, Cy @ΠD, Σz <, Report ® TrueD; MatrixList@%D Size@7D
-1 0 0 : 0 -1 0 , 0 0 -1 -1 0 0 0 1 0 , 0 0 1
-1 0 0 0 -1 0 , 0 0 1 1 0 0 0 -1 0 , 0 0 -1
-1 0 0 0 1 0 , 0 0 -1 1 0 0 0 -1 0 , 0 0 1
1 0 0 0 1 0 , 0 0 -1
1 0 0 0 1 0 > 0 0 1
The International name mmm says it is generated by three perpendicular mirrors, which are certainly there. We just check that mmm actually does the whole job: mmmGroup = MakeGroup@8Σx , Σy , Σz <, Report ® TrueD; MatrixList@%D Size@7D
-1 0 0 : 0 -1 0 , 0 0 -1 -1 0 0 0 1 0 , 0 0 1
-1 0 0 0 -1 0 , 0 0 1 1 0 0 0 -1 0 , 0 0 -1
-1 0 0 0 1 0 , 0 0 -1 1 0 0 0 -1 0 , 0 0 1
1 0 0 0 1 0 , 0 0 -1
1 0 0 0 1 0 > 0 0 1
D2hCalc == mmmGroup True
All is well. The name mmm cannot be shortened, because mm is C2v, as we saw above.
215
18. Tabulated representations of groups Preliminaries
18.1 Cartesian representation tables 18.1.1 Introduction In this chapter we discuss the package operator CartesianRepresenta tionTable, or CartRep for short, first defined back in Chapter 8 ( MultiplicationTables). All the group names returned by GroupCatalog have a CartRep kept in the Symmetry` package : GroupCatalog
8C1, C2, C2h, C2v, C3, C3h, C3v, C4, C4h, C4v, C5, C6, C6h, C6v, Ch, Ci, D2, D2d, D2h, D3, D3d, D3h, D4, D4d, D4h, D5, D5d, D5h, D6, D6d, D6h, I, O, Oh, S4, S6, S8, T, Td, Th<
The official group names are written with subscripts raised to the main line, and must be enclosed in quotes when fed to an operator. These 41 point groups include all 32 groups that describe the unit cells of crystals, plus other symmetries possessed by molecules, but which cannot serve as a unit cell symmetries. In this chapter we present operators that construct from scratch the groups Cn , Dn , Dnd , Sn Hn evenL , T, O, and I. The other groups may be constructed as product groups; indeed, their names are based on this fact. In detail, Cnh = Cn Ä Ch or Cn Ä Ci Cnv = Cn Ä C¢2 Dnh = Dn Ä Ch or Dn Ä Ci Ih = I Ä Ch or I Ä Ci Oh = O Ä Ch or O Ä Ci Th = T Ä Ch Td = T Ä Ci Our group-making operators return their results in infinite precision for all the tabulated groups. But usually they will not work for n higher than 6, because (with some exceptions) Mathematica does not evaluate expressions like Cz @2 Π nD in infinite precision for n higher than 6. But if you just include a decimal after the fold-number n (like Cz @2 Π 7.D) all operators return a correct answer in machine precision. Most of the tabulated representations are generated automatically in infinite ry` W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, 217 for DOI 10.1007/b13137_18, © Springer Science+Business Media, LLC 2009 on “ ffey. They do not contain errors: any typo in the basic matrices or in the Cayley
Symmetry Theory
Most of the tabulated representations are generated automatically in infinite precision from a few basic matrices every time you load the Symmetry` package. (Infinite precision groups with five-fold axes are an exception, for trivial reasons, discussed in the End Notes.) The formulas are based on “ Cayley diagrams” for each group, constructed by a method explained in Duffey. They do not contain errors: any typo in the basic matrices or in the Cayley formulas would produce massive errors in the MultiplicationTable of the group, and these are not seen. The Cayley method is fast but not very informative. In this chapter, we follow the Schönflies classification scheme of Chapter 17 (Naming Groups), as made more specific by each group's Presentation information, brought up by commands like Presentation@"O"D a.a.a.a b.b.b a.b.a.b.a.b.a.b e
This example says that group O is the closure of any two matrices, a and b that obey the relations shown. The first, a.a.a.a == e, says that a is a four-fold rotation, while b.b.b == e says that b is a three-fold rotation. The angle between the a and b axes is implicit in the relation (a.b).(a.b).(a.b). (a.b)== e. This is a beautiful orientation-free way of specifying the group O uniquely. Our concrete presentation matrices will agree with the orientation rules (next Section). We then feed them to MakeGroup, developed in Chapter 15. Then we check that the generated group is identical to the tabulated group. This is our basic check on the correctness of the tables. After you understand the construction scheme, you may wonder why we go to the trouble of tabulating all the representations. Why not just give people the tools, and let them do it on their own? It is because there is no unique or systematic way to order the elements of the groups, and the ordering is important to many uses of the group representations. The ordering can be established only by standard tables. You may not want to read this whole chapter at one sitting because it is long and systematic, intended as a reference on the construction of any point group you may become interested in, tabulated or not. We cannot go above six-fold axes in infinite precision, and there are times when you may want higher groups. This chapter is a manual on how to construct them in machine precision. Read until you get the idea, then have a look at the Platonic groups (which are a little different), then skip on to the next chapter. You can come back to any particular group whenever you need to.
218
Cartesian tables
18.1.2 Orientation conventions Cartesian transform matrices must refer to absolute orientations in space, and the orientations must be chosen by convention. Once and for all, here they are : 1. The horizontal plane is the x,y plane. Planar molecules always lie in this plane. 2. If there is a unique axis of highest symmetry, it is the z axis. 3. When there are rotation axes in addition to z, one must lie in the z,x plane. 4. When there are vertical reflection planes (i.e., planes containing the z axis), one must be the z,x plane. But if this conflicts with rule 3 (as in the Dn d groups), then rule 3 takes precedence. 5. In the Platonic groups, there is no unique highest axis. (a) In the T groups, z is two-fold and {1,1,1} is three-fold. (b) In the O groups, z and x are fourfold axes. (c) The I groups take z as two-fold, plus a five-fold in the z,x plane, at angle Α to the z axis such that 2
Sin[Α]= 5+
and Cos[Α] = 5
1 2
1
+ 2
. 5
Nearly everyone agrees on the first two conventions. Agreement on the others is not so universal, but we will try to stick to them in this book. Molecule definitions also have to follow these rules if you want to use the tools of this book on them. For instance, never define a planar molecule to lie in the z,x plane or the y,z plane. Planar molecules must obey the group (or subgroup) Ch , which uses the x,y plane. This is why we do not include any group Cv among our tabulated groups; by these conventions no molecule can belong to Cv .
18.1.3 An example of a Cartesian Representation The command CartesianRepresentation["gpNm"], where "gpNm" is any group name from GroupCatalog, brings up the entire matrix group. For instance, 219
Symmetry Theory
CartesianRepresentation@"C3"D GridList :
1 0 0
0 1 0
- 12 3
0 0 1
-
3 2
,
,
2
- 12
0
0
0
1
3
- 12
0
-
3 2
2
0
- 12
0
0
1
0
>
The abbreviation CartRep, which we usually use, does exactly the same job. These are 3 ´3 Cartesian transform matrices that “ represent” the group (obey its multiplication table). Any one of them can be dotted into a Cartesian point {x,y,z} on its right, producing the new position of the point after the symmetry operation. Therefore, as will be fully explained in Chapter 25 (Representations), the CartReps are “{x,y,z} representations”.
18.1.4 Auxiliary operators There are several auxiliary operators that help you use the CartReps. First, every matrix of every group has a specific name : ElementNames@"C3"D FullForm List@"E", "C3", "C32"D
The names are strings, and you must not omit the quotes when you feed them to an operator. The names are in the same order as the matrices returned by CartRep. It is often easier to specify operations using matrix names rather than the matrices themselves. Here is pseudo-symbolic multiplication of matrices C3 and C32 from group C3 : "C3"."C32" . NamesToRepMats@"C3"D . RepMatsToNames@"C3"D E
The thumbnail sketch of NamesToRepMats is
220
Cartesian tables
NamesToRepMats["g"] returns rules that replace the name of each element of group "g" by its Cartesian representation matrix. The inverse rules are given by RepMatsToNames["g"].
18.2 Very simple groups 18.2.1 One element For completeness, we begin with group C1 , which consists only of the identity matrix E. Even the most unsymmetric objects remain unchanged (are symmetric) under E. Issue CartRep["C1"] to see the actual matrix.
18.2.2 Two-element groups Next in simplicity come the two-element groups Ci , C2 , Ch , and Cv . They are all isomorphic to each other, so to an abstract group theorist they are all the same. But geometrically, they are very different. A two-element group can have only elements E and X. In its multiplication table the entries EX X are fixed by the format of the table. The fourth entry must be either E or X. If it were X the table would be Latin square. So it must be
E X X E
E X X X
, which is not a
.
1. Group Ci contains only the unit Emat and the inversion matrix Imat. Issue CartRep["Ci"] to see the matrices. The inversion is not used in the Schönflies system of naming, but is used extensively in International (every axis with a bar over it is a rotation times in inversion.) There are simple molecules that belong to this group and to no higher group; for example, here is C2H2Br2 Cl2staggered.
221
Symmetry Theory
Fig. 18.1 Stereo pair for a molecule that possesses only inversion symmetry
2. Group C2 contains only E and a C2 axis, which by convention must be the z axis. Issue CartRep["C2"] to see the matrices. Many protein and nucleic acid dimers have only a C2 axis. The smallest molecule with only a C2 axis is a deuterated borane transHB3H2D2 :
Fig. 18.2 Stereo pair for a molecule that possesses only a twofold rotation
4. Group Ch has a horizontal reflecting plane. Issue CartRep["Ch"] to see the matrices. All triatomic molecules ABC with three different atoms belong to Ch , and to no higher group. The orientation rules say all three atoms should be in the horizontal plane. 5. Group Cv has only a vertical reflection plane. This group is not in the catalog because the vertical reflection plane can be at any angle Θ to the z,x plane, and this causes trouble with some of our auxiliary operators. If a reflection plane contains the point {Cos[Θ],Sin[Θ],0} then its reflection matrix is Cos@2 ΘD Sin@2 ΘD 0
222
Sin@2 ΘD -Cos@2 ΘD 0
0 0 1
Simple groups
On your own Prove this using the ReflectionMatrix operator.
18.3 Groups with a principal axis 18.3.1 Introduction In the next three sections we enumerate all the point group types that have a unique axis of highest symmetry. This axis may be either a rotation or rotoreflection. Only a limited number of other elements may be added to the principal axis to make a generator list for a finite point group. All possible cases are listed systematically below.
18.3.2 Groups Cn , Cnh , and Cnv Groups Cn As always, look first at the presentation: Presentation@"C3"D a.a.a e
This says that C3 is generated by a list containing only one matrix, a three-fold rotation. Rule 2 says it has to be the z axis. Generalizing, Cn needs an n-fold rotation about z : MakeCn @int_D := Module@8op<, If@int == 5, op = PentaDot, op = DotD; MakeGroup@op, 8Cz @2 Π intD
The five-fold z axis presents a difficulty in infinite precision calculations, so case 5 alone uses a special operator called PentaDot, defined in the Symme try` package. It is the usual Dot operator with some special simplifications for five-fold z axes. Click to the End Notes for a full discussion. The threefold rotation group is the briefest: groupC3 = MakeCn @3D; % MatrixList Size@6D
223
Symmetry Theory
:
-
1
3
-
2 3
-
2
0
-
0
2
1
3
2
2
,
1
0
2
0
3
-
1
-
2
0
0
1 0 0 0 1 0 > 0 0 1
,
1
0
2
0
1
Is this the same as the tabulated group? The ordering of the matrices is unlikely to be the same, so always Sort before asking the equality question. Sort@groupC3D == Sort@CartRep@"C3"DD True
Make sure that the special case 5 works smoothly. Look at just the last two matrices: groupC5 = MakeCn @5D; Take@% Sort, -2D GridList Size@5D 1
-1 +
-
5
4
:
1
1
2
2
5+
5
1
0
-1 +
5
4
1
1
2
2
5+
5
0 >
, 1
1
2
2
5+
5
1
-1 +
5
0
4 0
0
-
1
1
2
2
1
5+
5
1
-1 +
5
0
4 0
0
1
Those radicals under radicals are the source of the difficulty. But the generated group is correct: Sort@groupC5D == Sort@CartRep@"C5"DD True
Groups Cnh The Cnh groups are product groups Cn Ä Ch , so they are just rotations with a horizontal mirror. The presentation is Presentation@"C3h"D a.a.a b.b a.b.Inverse@aD.b e
By Rule 1, matrix b must be the horizontal mirror Σxy . Check the presentation : aMat = RotationMatrix3Dz@2 Π 3D; bMat = Σxy ; aInv = Inverse@aMatD; aMat.bMat.aInv.bMat == Emat True
It works. So the general operator for these groups is MakeCnh @int_D :=
224
Principal axis groups
Module@8op<, If@int == 5, op = PentaDot, op = DotD; MakeGroup@op, 8Cz @2 Π intD, Σxy
groupC3h = MakeCnh @3D; Sort@groupC3hD == Sort@CartRep@"C3h"DD True
Groups Cnv The Schönflies name Cnv implies a product group Cn Ä Cv , as detailed previously in Chapter 16, ProductGroups. The presentation confirms this : Presentation@"C3v"D a.a.a b.b a.b.a.b e
By Rules 2 and 4, a is a z-rotation and b is Σzx .
MakeCnv @int_D := Module@8op<, If@int == 5, op = PentaDot, op = DotD; MakeGroup@op, 8Cz @2 Π intD, Σzx
Check it :
groupC3v = MakeCnv @3D; Sort@groupC3vD == Sort@CartRep@"C3v"DD True
18.3.3 The Sn groups (n even) The axial rotoreflection groups Sn are based on powers of a roto-reflection (NOT a roto-inversion) about the z axis. The only subtlety is that the name Sn is used only for even n. You will see why. Presentation@"S4"D a.a.a.a e
The presentation agrees.
Clear@MakeSn D; MakeSn @int_D :=
225
Symmetry Theory
MakeGroup@Dot, 8AxialRotoReflection@80, 0, 1<, 2 Π intD
To understand the restriction to even integers, look at the group generated by groupS3 = MakeGroup@Dot, 8AxialRotoReflection@80, 0, 1<, 2 Π 3D
:
1 2 3
2
0
-
3
-
1
-
1
3
2
2
2
0
,
-
1
-1
, 0
1 0 0
0 0 -1
1
3
2
2
,
1
-
0
2
0
0 1 0
-
0
2
-
0
0
3
-
2
2
2
0
1
3
0
2
0
3
-
0
2
1
,
1 0 0
3
-
2
0
0 1 0
0 0 1
1
0 , 0
2
0
-1
>
1
It is based on the rotoreflection by a third of a turn, but the cycle has six members! Furthermore, half the matrices have -1 in position 3,3. That makes it look like a product with group Ch . Is it? Sort@groupS3D == Sort@CartRep@"C3"D Ä CartRep@"Ch"DD True
Indeed it is. Schönflies used product group names as much as possible, (product group calculations are so much quicker if you work by hand) so instead of calling it S3 , he called it C3 h .
226
Principal axis groups
On your own This operator happens to work in infinite precision for 8 and 12. Try it. Make a big numerical Sn group and Map the operator RecognizeMa trix on it. Note that rotation matrices alternate with rotoreflection matrices. Then try an odd integer, as in MakeSn @3D. You will see it refuse to evaluate because the Condition is not True. Then try a higher even integer, as in MakeSn @10.D. The decimal tells it to work numerically, so you will see a numeric version of group S10 .
18.3.4 Groups Dn , Dnh , and Dn d Groups Dn The Dn groups are always pure rotation groups, with an n-fold rotation around the principal axis and another n two-fold rotations about horizontal axes. Presentation@"D3"D a.a.a b.b a.b.a.b e
By Rule 2, a is a three-fold rotation about z. By Rule 3, the b axis must lie in the z,x plane, but where? You could work it our from a.b.a.b e, but you know from the D in the name that it must be the x axis. Clear@MakeDn D; MakeDn @int_D := Module@8op<, If@int == 5, op = PentaDot, op = DotD; MakeGroup@op, 8Cz @2 Π intD, Cx @2 Π 2D
Click back to the Cn groups if you need to review PentaDot. Try it out: Sort@MakeDn @3DD == Sort@CartRep@"D3"DD True
227
Symmetry Theory
On your own The Dn,h groups are products of group Ch with the groups Dn . Show this symbolically, following the models above.
Groups Dnh The name implies a product group Dn Ä Ch . This is true, and the minimal presentation agrees: Presentation@"D3h"D a.a.a b.b c.c a.b.a.b b.c.b.c a.c.Inverse@aD.c e
By Rule 2, a is a three-fold rotation about z. By Rule 3, b is a two-fold about x, and by Rule 1, c is the horizontal reflection plane Σxy . Clear@MakeDnh D; MakeDnh @int_D := Module@8op<, If@int == 5, op = PentaDot, op = DotD; MakeGroup@op, 8Cz @2 Π intD, Cx @2 Π 2D, Σxy
Groups Dnd The name implies a product group Dn Ä Cd , which is the way Schönflies looked at it. But this was the tragic error which led crystallographers to the reject Schönflies notation. Here is a quick demonstration. Ask if the Dnd groups contain the inversion matrix Imat, or not : Map@FreeQ@CartRep@ðD, ImatD &, 8"D2d", "D3d", "D4d", "D5d", "D6d"
8True, False, True, False, True<
All the odd-n groups contain inversion center, while the even-n groups do not! The International system splits the Dnd groups into two series with quite differ ent names. There is the odd series 8D3 d , D5 d , ¼< = 93 m, 5 m, ¼= and the even series 8D2 d , D4 d , ¼< = 94 2 m, 8 2 m, ¼=. Remember that a bar over an integer means roto-inversion axis, a concept that Schönflies did not use. For more on this, click to the End Notes. Where does the inversion center come from? It is easy to see from Fig. 18.3 (below) that all the odd-n groups have a reflection in the y,z plane, while the 228 even-n groups do not. It is the product of this reflection times the 2-fold rotation about x that produces the inversion center :
Principal axis groups
Where does the inversion center come from? It is easy to see from Fig. 18.3 (below) that all the odd-n groups have a reflection in the y,z plane, while the even-n groups do not. It is the product of this reflection times the 2-fold rotation about x that produces the inversion center : Imat == AxialReflection@81, 0, 0
Here are the pictures : y
y
D2d
x
y
x
y
D5d
x
y
D3d
D4d
x
D6d
x
Fig. 18.3 A top view of the elements of the tabulated Dn,d groups. The horizontal C2 axes are black, and the edges of the Σv planes are red.
The black C2 axes are connected by a polygonal rim for visual clarity. By convention, one of them is the x-axis. The edges of the dihedral reflecting planes are in red. These figures have 2n-fold symmetry, not n-fold. This means that the angle between any two adjacent C2 axes is 2Π/(2n), and therefore that the angle between a C2 axis and the adjacent dihedral plane is 2Π/(4n). Generate group Dnd For a discussion of the Presentation for Dnd , click to the End Notes. We follow Schönflies in constructing these groups as Dn Ä Cd . His way has at least the advantage of doing them all in a unified way, as an n-fold rotation about z, a two-fold rotation about x, and a dihedral reflection matrix at Π/(2n). The dihedral mirror is in a different position in each group, so it is constructed by the operator DihedralReflMat[n]. Flip to (or click to) the End Notes to see it developed. Here we just use it in the group generator :
229
Symmetry Theory
Clear@MakeDnd D; MakeDnd @int_D := Module@8op<, If@int == 5 ÈÈ int == 10, op = PentaDot, op = DotD; MakeGroup@op, 8Cz @2 Π intD, Cx @ΠD, DihedralReflMat@intD
:
-1 0 0
0 -1 0
0 0 , 1
-1 0 0
0 1 0
0 0 , -1
0 -1 0
-1 0 0
0 0 , 1
0 1 0
-1 0 0
0 0 , -1
0 -1 0
1 0 0
0 0 , -1
0 1 0
1 0 0
0 0 , 1
1 0 0
0 -1 0
0 0 , -1
1 0 0
0 1 0
0 0 > 1
Make sure it agrees with the tabulated group : Sort@groupD2dD == Sort@CartRep@"D2d"DD True
Run MakeDnd for 2 through 6 and compare to the tables:
TestDnd @int_D := Module@8gpName, byTable, byConstruction<, gpName = "D" <> ToString@intD <> "d"; byTable = CartRep@gpNameD Sort; byConstruction = MakeDnd @intD Sort; byTable == byConstruction D Map@TestDnd , 82, 3, 4, 5, 6
8True, True, True, True, True<
We said in the introduction that our group-making operators work with decimal numbers beyond 6, returning numeric results. Try it, looking at only two mats: MakeDnd @9.D; %P83, 4
:
-0.939693 -0.34202 0
-0.34202 0.939693 0
0 0 -1.
,
-0.939693 0.34202 0
-0.34202 -0.939693 0
0 0 1.
>
Numeric, as advertised. The crown ethers have high Dnd symmetries, so this is not completely academic.
230
Principal axis groups
On your own It happens that MakeDnd works in infinite precision for the non-catalog group D10 d . You can generate it just like D5 d , above.
18.4 Platonic groups There are infinitely many groups in all the uniaxial types enumerated above, because the axis order can go to infinity. After these, there are exactly seven more point groups. They are all based on the Platonic solids. The Platonic solids are bounded by identical equilateral polygons. There are exactly five of them: the tetrahedron (4 triangular faces), the cube (6 square faces), the octahedron (8 triangular faces), the dodecahedron (12 pentagonal faces), and the icosahedron (20 triangular faces).
Tetrahedron
Cube
Dodecahedron
Icosahedron
Octahedron
Fig. 18.4 The five Platonic solids. Three-D space does not support any others.
They are called “Platonic” because Plato based a prescientific theory of atoms on them. However, it may be that they were first discovered in Scotland. Like the Platonic solids, the Platonic groups contain several axes of the same highest order. Before calculating CartRep of a Platonic group, its solid must be given a standard orientation according to Rules 5a, b, and c at the top of this chapter.
18.4.1 Group T (tetrahedral rotations)
231
Symmetry Theory
18.4.1 Group T (tetrahedral rotations) Schönflies defined group T as all the rotations of the tetrahedron, with no attempt to base the name on a minimal list. The Presentation says that the minimal list consists of only two rotations, a two-fold and a three-fold: Presentation@"T"D a.a.a b.b a.b.a.b.a.b e
This agrees with the International name 23 But it is up to us to derive from classical geometry the angle between these axes. Following Rule 5a, look at a tetrahedron inscribed in a unit cube, with one vertex at {1,1,1} and the others at alternating corners of a cube of edge length 2, centered squarely on the coordinate axes. You will see that all the coordinate axes are two-fold symmetry axes, and that a slanted three-fold rotation axis runs through each of the four apices and out though the centroid of the opposite face. The red axes below are the two we use as to generate the group.
Fig. 18.5 The two generating axes of group T, in red.
So the minimal generating list is
aMatT = AxialRotation@81, 1, 1<, 2 Π 3D; bMatT = AxialRotation@80, 0, 1<, ΠD;
Feed them to MakeGroup. Watch it close in two rounds of calculation:
232
Platonic groups
groupT = MakeGroup@Dot, 8aMatT, bMatT<, Report ® TrueD Sort Reverse;
2 elements made 6 elements 6 elements made 12 elements 12 elements made 12 elements It is a very simple and beautiful group :
groupT NeatList Size@6D
:
1 0 0
0 1 0
0 0 , 1
1 0 0
0 -1 0
0 0 , -1
0 0 1
1 0 0
0 1 , 0
0 0 -1
1 0 0
0 -1 , 0
0 1 0
0 0 1
1 0 , 0
0 -1 0
0 0 -1
1 0 , 0
0 1 0
0 0 -1
-1 0 , 0
0 -1 0
0 0 1
-1 0 , 0
0 0 -1
-1 0 0
0 1 , 0
0 0 1
-1 0 0
0 -1 , 0
-1 0 0
0 1 0
0 0 , -1
-1 0 0
0 -1 0
0 0 > 1
On your own Map the operator RecognizeMatrix onto these matrices You will see that it is a pure rotation group. There are three two-fold axes and four three-fold axes. Why does each three-fold axis yield two groups elements, while the two-fold axes yield only one?
18.4.2 Group Th From its name, it seems that Schönflies constructed it as a product group of T times Ch . But the minimal list is a three-fold rotation about {1,1,1} plus a horizontal reflection: groupTh = MakeGroup@Dot, 8AxialRotation@81, 1, 1<, 2 Π 3D, Σz <, Report ® TrueD;
2 elements made 6 elements 6 elements made 15 elements 15 elements made 24 elements 24 elements made 24 elements Is it the same as the tabulated group? 233
Symmetry Theory
Is it the same as the tabulated group? Sort@groupThD == Sort@CartRep@"Th"DD True
Its 24 matrices all have six 0's and three ±1's, like those of T. Call them up with groupTh NeatList Size@6D
:
-1 0 0
0 -1 0
0 0 , -1
-1 0 0
0 -1 0
0 0 , 1
-1 0 0
0 1 0
0 0 , -1
-1 0 0
0 1 0
0 0 , 1
0 0 -1
-1 0 0
0 -1 , 0
0 0 1
-1 0 0
0 -1 , 0
0 0 -1
-1 0 0
0 1 , 0
0 0 1
-1 0 0
0 1 , 0
0 -1 0
0 0 -1
-1 0 , 0
0 -1 0
0 0 1
-1 0 , 0
0 1 0
0 0 -1
-1 0 , 0
0 1 0
0 0 1
-1 0 , 0
0 -1 0
0 0 -1
1 0 , 0
0 -1 0
0 0 1
1 0 , 0
0 1 0
0 0 -1
1 0 , 0
0 1 0
0 0 1
1 0 , 0
0 0 -1
1 0 0
0 -1 , 0
0 0 1
1 0 0
0 -1 , 0
0 0 -1
1 0 0
0 1 , 0
0 0 1
1 0 0
0 1 , 0
1 0 0
0 -1 0
0 0 , -1
1 0 0
0 -1 0
0 0 , 1
1 0 0
0 1 0
0 0 , -1
1 0 0
0 1 0
0 0 > 1
18.4.3 Group Td Group Td comprises all the symmetries of the tetrahedron, rotations and reflections. It may be T Ä Cd , but the Presentation says the minimal list is a fourfold and a threefold: Presentation@"Td"D a.a.a.a b.b.b a.b.a.b.a.b.a.b e
The fourfold is a rotoreflection, not a rotation. The threefold is the usual cube diagonal. It closes in three rounds of calculation : groupTd = MakeGroup@Dot, 8 AxialRotoReflection@80, 0, 1<, Π 2D, AxialRotation@81, 1, 1<, 2 Π 3D<, Report ® TrueD;
2 elements made 6 elements 6 elements made 22 elements 22 elements made 24 elements 24 elements made 24 elements Sort@groupTdD == Sort@CartRep@"Td"DD True
If you run the command 234
Platonic groups
If you run the command
Map@RecognizeMatrix, groupTdD Sort
you will see that Td has six reflecting planes, each bisecting the tetrahedron and containing one of its six edges. These are the dihedral planes that give the name its subscript d. If you run the next command, you will see 24 beautifully simple matrices: groupTd NeatList Size@6D
18.4.4 Group O (octahedral rotations) Group O is the group of all the rotations of the octahedron; or equivalently, the group of all the rotations of the cube. Here is an odd fact : Presentation@"O"D == Presentation@"Td"D True
Explicitly, Presentation@"O"D a.a.a.a b.b.b a.b.a.b.a.b.a.b e
It is a fourfold and a threefold. But orientation rule 5b, above, says it must include four-fold rotations about the z and x axes. So is it also possible to construct it from two perpendicular fourfold rotations? groupO = MakeGroup@Dot, 8Cx @2 Π 4D, Cz @2 Π 4D< N, Report ® TrueD;
2 elements made 6 elements 6 elements made 21 elements 21 elements made 24 elements 24 elements made 24 elements Does this agree with the tabulated group ? Sort@groupOD == Sort@CartRep@"O"DD True
235
Symmetry Theory
18.4.5 Group Oh Group Oh consists of all the symmetries of the octahedron; or equivalently, all the symmetries of the cube. It is the product of groups O and Ch . Sort@CartRep@"O"D Ä CartRep@"Ch"DD == Sort@CartRep@"Oh"DD True
But its short list has only two elements in it : Presentation@"Oh"D a.a.a.a b.b a.b.a.b.a.b.a.b.a.b.a.b e
This must mean a vertical four-fold rotation and a reflecting plane (because two rotations cannot generate a reflection, and the cube has many reflections). But which plane? Looking at the octahedron, you can see that one of them is perpendicular to {1,0,1}, so we use that: aMat = RotationMatrix3Dz@2 Π 4D; bMat = ReflectionMatrix@81, 0, 1
That works. So now make the group and test it:
groupOh = MakeGroup@Dot, 8aMat, bMat
Again, it is beautifully simple. All elements are similar to the first 6:
Take@groupOh , 6D Sort Reverse GridList Size@6D
:
-1 0 0
0 0 1
-1 0 0
0 0 -1
236
0 1 0 0 -1 0
-1 0 0
,
,
-1 0 0
0 0 -1 0 -1 0
0 1 0
-1 0 0
,
0 0 1
,
-1 0 0
0 0 1
0 -1 0 0 -1 0
,
0 0 -1
>
Platonic groups
18.4.6 Group I (icosahedral rotations) Group I is the group of all the rotations of the icosahedron; or equivalently, of the dodecahedron. The International name of this group is 52, implying that it is generated by a fivefold axis and a twofold axis. The icosahedron is the least familiar of the Platonic solids. Strangely, the Greeks never understood the icosahedron completely. The climax of Euclid's books on geometry is the construction of the icosahedron (Book XIII, proposition 18) but he failed to see the one fact that makes the icosahedron easily understandable. Schönemann finally discovered it in 1873, some 2200 years after Euclid. The icosahedron is built around a skeleton of three interlocking Golden Rectangles, and using this he was the first to list the Cartesian coordinates of their vertices. An excellent modern exposition has been given by Coxeter. We give a quick sketch of it just below. Modern construction of the icosahedron The sides a and b of the Golden rectangles obey the classic Greek “golden” proportion a+b == ab , where a is the long side and b is the short side. The a golden ratio Γ is a/b . Setting a = Γ and b = 1, Clear@ΓD; ΓSolns = SolveB ::Γ ®
1 2
J1 -
Γ+1 Γ
5 N>, :Γ ®
== 1 2
Γ 1
, ΓF
J1 +
5 N>>
We want the positive solution : Γ=
1 2
J1 +
5 N;
We draw three perpendicular golden rectangles, intersecting at the origin. One is in the xy plane (long in the x-direction), one is in the yz plane (long in the y direction), and one is in the zx plane (long in the z direction). Each rectangle has length 2Γ and width 2. threeGoldenRectangles 88Γ, 1, 0<, 8Γ, -1, 0<, 880, Γ, 1<, 80, Γ, -1<, 881, 0, Γ<, 81, 0, -Γ<,
= 8 8-Γ, -1, 0<, 8-Γ, 1, 0<<, 80, -Γ, -1<, 80, -Γ, 1<<, 8-1, 0, -Γ<, 8-1, 0, Γ<<<;
237
Symmetry Theory
Fig. 18.6 Three perpendicular golden rectangles; the heart of the icosahedron
It is easy to calculate (with Mathematica) that each vertex is equidistant from its five closest neighbors. vertices = Flatten@threeGoldenRectangles N, 1D; DMofIcos = DistanceMatrix@verticesD; MatrixForm@%D PaddedForm@ð, 84, 2
0.00 2.00 3.80 3.24 2.00 2.00 3.24 3.24 2.00 2.00 3.24 3.24
2.00 0.00 3.24 3.80 3.24 3.24 2.00 2.00 2.00 2.00 3.24 3.24
3.80 3.24 0.00 2.00 3.24 3.24 2.00 2.00 3.24 3.24 2.00 2.00
3.24 3.80 2.00 0.00 2.00 2.00 3.24 3.24 3.24 3.24 2.00 2.00
2.00 3.24 3.24 2.00 0.00 2.00 3.80 3.24 2.00 3.24 3.24 2.00
2.00 3.24 3.24 2.00 2.00 0.00 3.24 3.80 3.24 2.00 2.00 3.24
3.24 2.00 2.00 3.24 3.80 3.24 0.00 2.00 3.24 2.00 2.00 3.24
3.24 2.00 2.00 3.24 3.24 3.80 2.00 0.00 2.00 3.24 3.24 2.00
2.00 2.00 3.24 3.24 2.00 3.24 3.24 2.00 0.00 3.24 3.80 2.00
2.00 2.00 3.24 3.24 3.24 2.00 2.00 3.24 3.24 0.00 2.00 3.80
3.24 3.24 2.00 2.00 3.24 2.00 2.00 3.24 3.80 2.00 0.00 3.24
3.24 3.24 2.00 2.00 2.00 3.24 3.24 2.00 2.00 3.80 3.24 0.00
The minimum vertex-vertex distance is 2.00, and it occurs five times in each row. That is, each vertex is surrounded by five equidistant nearest neighbor vertices. This is the definition of the icosahedron. Below, we draw the shortest vertex-vertex lines to show the icosahedron more clearly.
238
Platonic groups
Fig. 18.7 Three interlocked golden rectangles with nearest vertices joined. It's the icosahedron!
This icosahedron is not in standard orientation because its z axis is a twofold axis. The fivefold axes all lie on the diagonals of the golden rectangles. To put the figure in standard orientation, pick a five-fold axis in the zx plane and rotate about y by an angle Α to bring it to the vertical.
z
Α x
Fig. 18.8 Golden rectangle, with angle Α defined. Width is 2; height is 2 Γ.
We can write exact expressions for the Sin and Cos of Α : 8sinΑ, cosΑ< = :
1 , 1 + Γ2
:
2
1 ,
5+
5
10
J5 +
Γ
> FullSimplify
1 + Γ2
5N>
Icosahedron with vertical five-fold
239
Symmetry Theory
Icosahedron with vertical five-fold Two rotation matrices (about the z axis and the diagonal axis in the figure above) are all we need to generate group I. If you want the icosahedron to have a vertical five-fold (as it is usually depicted) use matA = AxialRotation@80, 0, 1<, 2 Π 5D Simplify; MatrixForm@%D J-1 +
1 4
5 8
5 N - 12 5 8
+
1 2
1 4
0
J5 +
J-1 +
5N
0
5N
0
0
1
plus a twofold about the diagonal axis.
matB = AxialRotation@8-sinΑ, 0, cosΑ<, ΠD FullSimplify; MatrixForm@ %D 1
-
0
2
-
5
0 2
-
5
-1
0
0
1
5
5
Icosahedron with vertical two-fold But to follow Rule 5c, we must take the two-fold as the z axis and the five-fold as the diagonal axis of the figure. Also, to calculate group Ih as a product of I and Ch , you must have a vertical two-fold. So we need 2
aMat = AxialRotationB: 5+
2 Π 5F FullSimplify;
% GridForm 1 2
1 4 1 4
240
J1 +
J-1 +
5N
5N
1 4 1 4
J-1 J-1 + 1 2
1 , 0,
5N 5N
2
5
1 4
J-1 + -
1 4
1 2
J1 +
5N 5N
>,
1
+ 2
5
Platonic groups
bMat = Cz @ΠD; % GridForm -1 0 0
0 -1 0
0 0 1
These matrices are the basis on which CartRep["I"] is calculated. The presentation of group I, the largest group we tabulate (60 elements) is no more difficult than any other point group: Presentation@"I"D a.a.a.a.a b.b a.b.a.b.a.b e
So a is the fivefold and b is the twofold, and the third matrix power of a.b must be unity. This is the acid test of whether we have the angle between the two rotation axes correct. Here it is: MatrixPower@aMat.bMat, 3D FullSimplify
881, 0, 0<, 80, 1, 0<, 80, 0, 1<<
Construction of group I As in many infinite precision calculations that involve 5 , we must make sure that all expressions equal in value are simplified to the same form. We insure this with a special Dot operator (like PentaDot) which we call Icosa Dot, defined in the Symmetry` package. Read about in the End Notes. Get ready to be amazed.
8timeI1, groupI< = MakeGroup@IcosaDot, 8aMat, bMat<, Report ® TrueD Timing; timeI1 Second
2 elements made 6 elements 6 elements made 19 elements 19 elements made 52 elements 52 elements made 60 elements 60 elements made 60 elements 8.78538 Second
Sort@groupID == Sort@CartRep@"I"DD True
Even the multiplication table works if you give it IcosaDot, and it takes only 15 seconds or so (MacBook Pro). We suppress the display: 241
Symmetry Theory
Even the multiplication table works if you give it IcosaDot, and it takes only 15 seconds or so (MacBook Pro). We suppress the display: 8timeI2, mtI< = MultiplicationTable@ IcosaDot, groupI, Range@60DD Timing; timeI2 Second 13.4219 Second
All this is infinite precision. Did it recognize every infinite precision product? FreeQ@mtI, "?"D True
On your own Try this one: Map[RecognizeMatrix,N[groupI]]//Sort//Chop//Colu mn You will find only rotation matrices.
On your own Repeat this construction using the simple Dot operator and a machine precision minimal list, and see how much faster it is.
18.4.7 Group Ih We do not tabulate this 120 element group, because it slows down the loading of the Symmetry` package. If you ever need it, construct it and send it to disk using groupIh >> fileIh. Here is the construction; it is almost instantaneous : groupIh = CartRep@"I"D Ä CartRep@"Ch"D; Dimensions@groupIhD 8120, 3, 3<
Interactive readers can see the whole thing, arranged by classes, by issuing
Map@RecognizeMatrix, N@groupIhDD Chop Sort Column Size@7D
Checking for closure takes about a minute :
242
Platonic groups
8timeIh, mtIh< = MultiplicationTable@ IcosaDot, groupIh, Range@120DD Timing; timeIh Second 53.5 Second
Did it close? FreeQ@groupIh, "?"D True
Coda If you ever find a point group that cannot be generated by the methods of this chapter, be sure to notify the American Mathematical Society. They will know what to do with you.
18.5 End Notes 18.5.1 Dihedral reflection planes for groups Dnd Look back to Fig. 18.3 (click here) to see where the dihedral mirror planes lie in the Dnd groups. Just below that figure we argued that the dihedral plane adjacent to the x-axis lies at angle 2Π/(4n). Here we make an operator that returns the matrix for this mirror. If we insist that all our tabulated Cartesian representations be in infinite precision (and we do) then the plane for D4 d presents a special problem. The dihedral plane at angle Θ contains the point {Cos[Θ],Sin[Θ],0}. So a vector perpendicular to this plane is given by {Sin[Θ],-Cos[Θ],0}. The first dihedral reflection plane (the one needed for Dnd generation lies) at Π/(2n). This means that n = 4 needs {Sin[Π/8],Cos[Π/8]}, and these are not evaluated in infinite precision. However, the trig functions for Π/4 are evaluated in infinite precision, so we can get exact expressions for Π/8 using the half-angle formulas FloorB
SinHalf@x_D := FullSimplifyBH-1L
x 2Π
F
1 - Cos@xD 2
FloorB
CosHalf@x_D := FullSimplifyBH-1L
x+Π 2Π
F
1 + Cos@xD 2
F; F;
Here are the functions of Π/8 in infinite precision: 243
Symmetry Theory
Here are the functions of Π/8 in infinite precision: 8SinHalf@Π 4D, CosHalf@Π 4D< :
2-
2 ,
2+
2
2
2
>
Do a numerical check :
8N@SinHalf@Π 4DD == N@Sin@Π 8DD, N@CosHalf@Π 4DD == N@Cos@Π 8DD< 8True, True<
The axis perpendicular to the first dihedral plane is therefore DihedralReflAxis@int_D := Π Π :SinHalfB F, -CosHalfB F, 0> int int Put this into the definition of the first n-fold dihedral reflection matrix Clear@DihedralReflMatD; DihedralReflMat@int_D := Map@ToRadicals, Map@FullSimplify, AxialReflection@DihedralReflAxis@intDDD . noEighthD (The replacement rule noEighth is discussed in another End Note.) For example, the plane for the 2-fold case lies at Π/4 (see Fig. 18.3), and the reflection matrix is DihedralReflMat@2D
880, 1, 0<, 81, 0, 0<, 80, 0, 1<<
This exchanges x and y coordinates, as it should. Try other examples for yourself, checking with RecognizeMatix.
18.5.2 Schönflies vs. International for the Dnd groups This name implies a minimal list of three elements (two matrices for Dn plus the matrix Σd ), but the presentation says there is a simpler way that uses only two elements: Presentation@"D2d"D a.a.a.a b.b a.b.a.b e
aMat = AxialRotoReflection@80, 0, 1<, 2 Π 4D; 244
End Notes
bMat = DihedralReflMat@2D; MatrixPower@aMat, 4D == MatrixPower@bMat, 2D == aMat.bMat.aMat.bMat == Emat True
groupD2d = MakeGroup@Dot, 8aMat, bMat<, Report ® TrueD;
2 elements made 6 elements 6 elements made 8 elements 8 elements made 8 elements Dimensions@CartRep@"D2d"DD 88, 3, 3<
Sort@groupD2dD == Sort@CartRep@"D2d"DD True
Presentation@"D3d"D a.a.a.a.a.a b.b a.b.a.b e
aMat = Cz @2 Π 6D.Σh ; bMat = DihedralReflMat@3D; MatrixPower@aMat, 6D == MatrixPower@bMat, 2D == aMat.bMat.aMat.bMat == Emat True
groupD3d = MakeGroup@Dot, 8aMat, bMat<, Report ® TrueD;
2 elements made 6 elements 6 elements made 12 elements 12 elements made 12 elements Dimensions@CartRep@"D3d"DD 812, 3, 3<
Sort@groupD3dD == Sort@CartRep@"D3d"DD True
245
Symmetry Theory
On your own Redo the whole calculation above, using aMat = Cz @2 Π 6D.Imat instead of aMat = Cz @2 Π 6D.Σh . It does make a D3 d group, but it is not the tabulated group.
18.5.3 Five-fold z-axis: PentaDot[mt1,mt2] Vexing problems can arise when you try to calculate radical expressions with infinite precision. Take the multiplication table C5 for example: MultiplicationTable@Dot, CartRep@"C5"D, Range@5DD MatrixForm 1 2 3 4 5
2 ? ? ? 1
3 ? ? 1 ?
4 ? 1 ? ?
5 1 ? ? ?
There is nothing wrong with the group; if you ask it to use a machine precision representation N[CartRep["C5"]], it works well : MultiplicationTable@Dot, N@CartRep@"C5"DD, Range@5DD MatrixForm 1 2 3 4 5
2 3 4 5 1
3 4 5 1 2
4 5 1 2 3
5 1 2 3 4
The problem is in the way MultiplicationTable recognizes identical products. Some of the products are generated as different forms that are numerically equal, and it correctly assigns a ? to the unfamiliar products. Here are two of the troublemakers:
formA =
1
1
2
2
J5 -
5 N ; formB =
5 8
-
5 ; 8
N@formAD == N@formBD True
Here is the most powerful simplification in Mathematica's core:
Map@ToRadicals, Map@FullSimplify, 8formA, formB
246
End Notes
:
1
1
2
2
J5 -
5N,
5
-
8
5 8
>
On your own Try Simplify alone, and then FullSimplify alone. The latter is a bit surprising the first time you see it. This explains why ToRadi cals has to be applied last. To put them in the same form, Mathematica would have to make an arbitrary choice, which by design it almost never does. So we make the arbitrary choice for it, as a little Rule called noEighth: noEighth = :
5
+
8
5
®
8
1
1
2
2
5+
5 5
, 8
-
5 8
®
1
1
2
2
5-
5
>;
Fortunately, these two ambiguities are the only ones that arise when working with axial five-fold groups. So in the Symmetry` package we define a special version of the Dot operator, called PentaDot, that contains this choice of form : H*NOT EVALUATABLE*L PentaDot@mat1_, mat2_D := ToRadicals@ FullSimplify@Dot@mat1, mat2DDD . noEighth;
The cell above is not evaluatable because it repeats a definition already made in the Symmetry` package. With this fancy operator, the table closes in infinite precision : MultiplicationTable@PentaDot, CartRep@"C5"DD MatrixForm 1 2 3 4 5
2 3 4 5 1
3 4 5 1 2
4 5 1 2 3
5 1 2 3 4
It is also important to use PentaDot in the MakeGroup operator when generating five-fold axial groups.
247
Symmetry Theory
On your own Make the multiplication tables for groups D5 , D5 h , and D5 d using both Dot and PentaDot. Use MakeGroup[PentaDot,{… }] to generate some of these groups.
18.5.4 Five-fold slanted axis: IcosaDot[mt1,mt2] Another simplification problem, similar to that in the five-fold axial groups, occurs in the icosahedral groups I and Ih . Again, the root of the problem is five-fold axes. The two expressions below are ambiguous in these groups : formC = J1 -
formD =
-1 5
5N
J5 -
1 10 5N
J5 + 1 2
5N;
J5 +
5N;
N@formCD == N@formDD True
Part of the cure is the rule list noTenth = : J1 -
5N
J-1 +
5N
J-5 +
5N
J5 -
5N
J5 +
1 10 1 10 1 10 1 10
5N ®
1 5
J-5 +
5N
1
J5 -
5N
1
2
J5 +
5N ®
J5 +
5 N ® J1 -
5N
1
5 N ® J-1 +
5N
1
J5 +
1 5
2
2
2
J5 +
5N,
J5 +
5N,
J5 +
5N,
J5 +
5 N >;
Try it out:
8formC, formD< . noTenth :
1 5
J-5 +
5N
1 2
J5 +
5N,-
1 5
J5 -
5N
1 2
J5 +
5N>
Now the radicals are the same, but there is a problem with the external sign. So we write a function noLeadingMinus that moves any leading minus sign inside the first factor of the expression : 248
End Notes
Now the radicals are the same, but there is a problem with the external sign. So inside the first factor of the expression : noLeadingMinus@f_D := Module@8g<, g = Simplify@fD Expand Factor; If@Dimensions@gD 83< && gP1T < 0, Apply@Times, 8-gP1T, -gP2T, gP3T
5N
1 2
J5 +
5N
1 2
J5 +
5NF
5N
It works. These two corrections are certainly not elegant or general, but they are all that is needed for the icosahedral groups. We put them together : H*NOT EVALUATABLE*L IcosaDot@a_, b_D := noLeadingMinus@Dot@a, bD . noTenthD
IcosaDot can be used just like PentaDot, with either Multiplication Table or MakeGroup.
18.5.5 Scotland, Scotland, über alles From the Wikipedia's article on Platonic solids: “ There is evidence that these figures were known long before the time of the Greeks. The neolithic people of Scotland constructed stone models of all five solids at least 1000 years before Plato (Atiyah and Sutcliffe 2003). These models are kept at the Ashmolean Museum in Oxford.” Check this out at http://en.wikipedia.org/wiki/Platonic_solid.
249
19. Visualizing groups Preliminaries
19.1 Constellations vs. stereograms 19.1.1 Introduction; the constellation operators In Chapter 15 (MakeGroup) we developed tools for generating every possible point group, and in Chapter 18 (CartesianRepresentations) we actually did it (well, not all of them). In books with paper pages one often sees a conventional diagram called a stereogram, a kind of polar projection of the symmetry elements of a group. Stereograms are a systematic way of presenting symmetries semi-visually, but they are not 3D-pictorial and one suspects that few people actually use them. In this electronic book, we think we have a better way. We will visualize the point groups by making geometric objects that have all the symmetries of any given point group (and no extra symmetry from higher groups). In mathematical group theory, the set of points generated by applying all the transforms of a group to some one point is called the orbit of the point, under the given group. In cyclic groups the orbit points really are placed like points on an orbit around the principal axis. But for other kinds of groups they are scattered, like a symmetric set of stars in space. With apologies to the mathematical community, we will call such a set a constellation instead of an orbit . In the Preliminaries of this chapter we define two special graphics operators; together, they can make figures showing the symmetries of the finite point groups. The names of the special operators are Constellate and MakeLines.
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_19, © Springer Science+Business Media, LLC 2009
251
Symmetry Theory
19.1.2 Constellate In the operator Constellate[pt,matList], parameter pt is a three dimensional point, and matList is a list of 3-by-3 transform matrices, usually a group of such matrices. A typical command would be {constellation,distanceMatrix}= Constellate[pt, matList] where constellation is the list of points created as the constellation of point pt by the transform matrices of matList, and where distanceMa trix is a matrix of all the distances between the points of the constellation. Both constellation and distanceMatrix are used by MakeLines to create the final figure.
19.1.3 MakeLines A typical command would be blueObjects = MakeLines[constellation, distanceMatrix,{1,3},"Blue"]; It uses the outputs of Constellate, plus a list of integers and a color. In this example the list {1,3} tells it to draw two kinds of lines: first, the 1 says to draw in all the shortest lines in the distance matrix; then the 3 says to draw in all lines of the third longest length. Similarly, {2} would tell it to draw in lines of only the second length, etc. The output of MakeLines is a Graphics3D object that includes all the constellation points and all the specified lines, all in the specified color. When we want lines of different lengths to be in different colors, we use MakeLines several times, combining all its graphic object outputs in one final list, which is fed to a rendering operator. When all desired graphics objects are collected together in a list, they are fed to StereoView.
252
Groups with principal axis
19.2 Constellations with a principal axis 19.2.1 Groups Cn and Sn We show one construction in the open; the rest will be closed. We use group C6 . The one point {1,0,0.15} constellates into six blue points and the shortest distance within the constellation is rendered as a blue line (six times). The point {0,0,1} constellates only onto itself, and is shown in red. Axes x, y, and z are shown in black.
Fig. 19.1 Stereogram for group C6
Let them fuse into a 3D image. The red dot lies on the only symmetry element that this group has (the z axis) so it makes a very defective constellation (namely, just itself). The most general constellation, a hexagon, is made by any point not on the z axis,
Fig. 19.2 Stereogram for group S6
The general constellation is a buckled hexagon, its points alternating equally 253 above and below the x,y plane. The red dot now makes a special two-point constellation. This is roto-reflection.
Symmetry Theory
The general constellation is a buckled hexagon, its points alternating equally above and below the x,y plane. The red dot now makes a special two-point constellation. This is roto-reflection.
19.2.2 Groups Cnh and Cnv Group Cnh adds a horizontal reflection plane to Cn , so the constellation now has two layers.
Fig. 19.3 Stereogram for group C4 h
Group Cnv adds vertical dihedral planes to Cn , starting with one in the z,x plane. This doubles the points horizontally.
Fig. 19.4 Stereogram for group C4 v
254
Groups with principal axis
19.2.3 Groups Dn These groups have an n-fold central axis and one or more horizontal 2-fold rotation axes. By our convention, one of the axes must be the x axis.
Fig. 19.5 Stereogram for group D4
There is a simplified red constellation and a general blue constellation. The individual eye-views are hard to interpret, but in stereo the picture is quite clear. The red dots lie directly on the horizontal C2 axes, so they have no rotation partners with respect to these axes. However, the pairs of blue dots linked by blue lines are C2 rotation partners. The green lines outline the top and bottom faces of a pseudoprism. A pseudoprism is a figure which is neither prism (eclipsed top and bottom faces) nor antiprism (staggered top and bottom faces), but somewhere between, with top and bottom faces twisted a little, but not to a symmetric position. The top face may be rotated (with respect to the bottom face) a little in the right-handed sense, or a little in the left-handed sense. The lateral faces are not plane parallelograms, but rather parallelograms broken into similar triangles, with a dihedral angle between them. Clearly this can be done in either of two ways (depending on which diagonal you pick as the dihedral intersection). Above we chose the way that makes the solid a convex solid.
19.2.4 Groups Dnh If you add a horizontal reflection plane to group D2 , you have group D2 h .
255
Symmetry Theory
Fig. 19.6 Stereogram for group D2 h
Group D2 h is the symmetry group of a brick. In the general case, group Dnh has an n-fold rotational symmetry about the central vertical axis, a horizontal reflection plane, and a set of horizontal C2 axes. It is quite instructive to look at this with a larger integer. Making the appropriate trivial change, the figure transforms itself to
Fig. 19.7 Stereogram for group D3 h
The group order of D3 h is 12, and the 12 blue dots show the most general constellation of this group. The three red dots lie on the three horizontal twofold axes, forming a less general constellation of their own.
19.2.5 Groups Dnd The generating elements of Dnd are an n-fold rotation about z, a 2-fold rotation about x, and a vertical reflecting plane at angle 2Π/(4 n). The vertical plane bisects the angle between two adjacent C2 axes. The picture for D4 d is
256
Groups with principal axis
Fig. 19.8 Stereogram for group D4 d
The Dnd groups are quite different for odd and even n. You can see easily that there is no inversion center above, but there is one below :
Fig. 19.9 Stereogram for group D5 d . Note the inversion center.
Now maybe you see why crown ethers belong to this group.
19.3 Constellations based on Platonic solids 19.3.1 Group T (rotations of the tetrahedron) Group T consists of all the rotations of the tetrahedron. The tetrahedron and the octahedron both belong to group T. But of course they are really of higher symmetry, possessing additional reflections not required in group T. But it is easy to generate the tetrahedral and octahedral vertices as constellations of group T. In the next cell we make a two complementary tetrahedra enclosing an octahedron : 257
The tetrahedron Symmetry Theory and the octahedron both belong to group T. But of course they are
of
additional reflections not
in
constellations of group T. In the next cell we make a two complementary tetrahedra enclosing an octahedron :
Fig. 19.10 Three special constellations of group T
The blue is the constellation of {1,1,1}; the green, of {1,1,-1}; the red, of {1,0,0}. None is general, having have fewer than 12 points. Below we construct a general constellation that belongs to group T, and to no higher group. Every coordinate axis is a twofold axis, and every cube diagonal is a threefold axis. But it has no reflection planes. First, we take a stereo view from an asymmetric perspective. The individual eye-views are difficult to interpret, but in stereo they are quite easy.
Fig. 19.11 General stereogram for group T.
There are 12 blue points, so this is the most general constellation of group T. It has 12 triangular faces, so it has the same connectivity as a dodecahedron. The brown dots are at tetrahedral vertices, just to help the eye organize this picture. Each blue vertex is five-coordinate, but the edges are of three different lengths, whereas in a true dodecahedron all edges are of equal length. If the blue lines shrink to zero, the figure becomes a tetrahedron. If the red lines shrink to zero, it becomes another tetrahedron. If the green lines shrink to zero, it becomes an octahedron. Below is a view down the x-axis (left) and a view down the cube diagonal (right). Note the two-fold and three-fold symmetries of the 2D figures. 258
Platonic groups
(right). Note the two-fold and three-fold symmetries of the 2D figures.
Fig. 19.12 Two different views of the general T constellation.
19.3.2 Group Th
A non-tetrahedral group
This group has a T-name because it is closely related to the tetrahedron, but the tetrahedron itself does not have this symmetry. However, both the cube and the octahedron may be constructed as constellations of group Th . We draw them together in conjugate position :
Fig. 19.13 Conjugacy of the cube and octahedron, using group Th .
The C3 axes of group T (the diagonals of the bounding box) become S6 axes in group Th . Here is a view directly down one of the S6 axes. Both the cube and the octahedron do possess S6 symmetry (around a body diagonal).
259
Symmetry Theory
Fig. 19.14 Three-fold rotational symmetry of the cube and octahedron.
Group Th has 24 elements, and things are starting to get complicated. Everything we have seen so far are special symmetric constellations; now we construct the most symmetric 24-point constellation of group Th . It is made of 18 squares and 8 triangles, all equilateral with each other. Each vertex is 4coordinate. The individual eye-views below are too busy to interpret easily, but in stereo it looks quite simple.
Fig. 19.15 General constellation of group Th , all edges of equal length.
If the classical geometers gave this solid a name, we have not been able to find it. (It is not the cuboctahedron.) It's a nice one though. But molecules that belong to Th do not need to look as simple as this constellation. Below, we draw a 24-point constellation with three different edge lengths that belongs to Th and to no higher group.
260
Platonic groups
Fig. 19.16 General constellation of group Th , with three different edge lengths.
This object has the same connectivity as the anonymous equilateral Th polytope constructed above, but it has three different edge lengths.
19.3.3 Group Td All symmetries of the tetrahedron Schönfliess defined group Td as all the symmetries of the tetrahedron. We construct the most general constellation of group Td , with 24 vertices and three different edge lengths.
Fig. 19.17 General constellation of group Td , with three different edge lengths.
The symmetry of group Td is so high that the general constellation is quite symmetric. It is a cube with alternate vertices frustrated in two different ways, deeply enough that the original cube edges are completely consumed. The six rectangular faces are all that is left of the original cube faces. The remaining eight six-sided faces divide into two types. Four of them relate like the faces of a tetrahedron, while the other four relate like the faces of the conjugate tetrahedron.
261
Symmetry Theory
19.3.4 Group O (rotations of the cube and octahedron) Group O is defined by Schönfliess as all the rotations of the octahedron. We draw the general 24-point constellation with three different edge lengths :
Fig. 19.18 General constellation of group O, with three different edge lengths.
A special symmetric constellation of this group was named by the classical geometers as the cuboctahedron. All its edges are the same length. It has 12 vertices and 12 faces; six of its faces are squares parallel to the faces of a cube; the other eight faces are triangles parallel to the faces of the conjugate octahedron.
Fig. 19.19 The cuboctahedon, as a constellation of point {1,1,0} in group O.
19.3.5 Group Oh (all symmetries, cube and octahedron) First, we display the cube and an inscribed octahedron, just to prove that they are both constellations of Oh .
262
Platonic groups
Fig. 19.20 The cube and the octahedron also belong to group Oh .
These simple figures are far short of the maximum number of points. To see the full complexity of group Oh , we must generate a constellation with 48 points.
Fig. 19.21 The most general constellation of group Oh . All 48 points were generated from a single point.
It is perhaps notable that Oh possesses an inversion, though it starts from a fourfold rotation and a single reflection.
19.3.6 Group I (rotations of dodecahedron and icosahedron)
Construction of a five-fold upright group I The International name of this group could be either 25 or 35, indicating that it is generated by a fivefold axis and a two-fold or a three-fold axis. Taking the five-fold axis as the z-axis, there is a threefold axis in the zx plane given by threefoldAxis = :-2 J3 +
5 N, 0, 7 + 3
5 >;
Therefore, a minimal generator list for this group consists of the matrices
263
Symmetry Theory
C5z = Cz @2 Π 5.D; C3q = AxialRotation@threefoldAxis, 2 Π 3.D; The decimals above make the whole thing numerical and very fast. groupI = MakeGroup@Dot, 8C5z, C3q
This group is not the same as our tabulated group I, but it works just as well. On your own It would be interesting to alter the graphics commands to work with the new two-fold upright version of group I in our tables. I would do it, but this book is taking too long already.
The icosahedron and dodecahedron Both the icosahedron and the dodecahedron can be drawn as constellations of this group. The icosahedron is the constellation of any point on a fivefold axis :
Fig. 19.22 The icosahedron as a constellation of any five-fold axis point in group I.
We know that one vertex of the dodecahedron lies on the threefold axis that was used to construct group I, so the dodecahedron is the constellation of any point on one of the threefold axes of the group :
264
Platonic groups
Fig. 19.23 Dodecahedron as a constellation of any three-fold axis point in group I.
The geodesic dome; the C60 molecule fullerene The icosahedron has only 12 vertices and the dodecahedron has only 20, so these figures are far from the general 60-vertex constellation of this group. We now present the most symmetric general constellation of group I, which is none other than Buckminster Fuller's fabulous geodesic dome. Its 60 vertices are all connected to three other vertices, and all its edges are the same length. Its faces are either pentagons or hexagons. Each pentagonal face is surrounded by five hexagons; each hexagonal face is surrounded by three hexagons alternating with three pentagons. It is easily generated as a constellation of group I, of a single carefully chosen point. (We use :4, 0,
5 + 2>.)
Fig. 19.24 The molecule buckminsterfullerene, C60 , as a constellation of group I.
There it is; the first fundamentally new architectural framework found since the middle ages; superbly light and strong. Buckminster Fuller used half of this structure to enclose sports arenas and other huge spaces. The molecule C60 forms in reasonable yield from carbon vapor under the right conditions. By changing the constellation point to anything not on a symmetry element we get the most general constellation for group I, with two different edge lengths. Below, the constellation point is {5,1,4}. 265
Symmetry Theory
Fig. 19.25 The most general constellation of group I.
It still has all 60 vertices; the fivefold axes are still in the center of pentagons, and the threefold axes are still in the center of triangles, but new rectangles have appeared to fill the gaps.
19.3.7 Group Ih (all symmetries, dodeca- and icosa- hedron) Here, at the very end of our catalog of point group constellations, we come to group Ih with 120 elements. The constellation is becoming too crowded to see much, even in stereo, so we will show only the top hemisphere of the constellations we create. But first, we must create the group. We construct it as the product of the group I we used above, with an inversion center. Being numerical, it's instantaneous: groupInv = 8Emat, Imat<; groupIh = groupI Ä groupInv; Dimensions@groupIhD 8120, 3, 3<
It has an inversion center and many reflecting planes, which I did not have. Map@RecognizeMatrix, groupIhD Chop Sort; Take@%, 3D
88identity<, 8inversion<, 8reflection, 80, 1., 0<<<
Mathematicians know of finite groups with unbelievably large numbers of elements. One, called “the monster”, has a precisely known number of elements said to be greater than the number of elementary particles in the universe. So don't get overwhelmed by Ih . Make the constellation for Ih of an arbitrarily chosen point, {1,0.3,1.2}, but show only the top half for visual clarity; 266
Platonic groups
Fig. 19.26 Top half of the most general constellation of group Ih .
The reflection planes of group Ih have done their job. The pentagons of the asymmetric geodesic dome of group I have expanded to become alternating decagons, and the triangles have expanded to become alternating hexagons. No known molecule has a symmetry this complex. Academic chemists may take this as a challenge.
19.4 That's it, folks. What Next? This completes the catalog of all possible kinds of point groups, and therefore the catalog of all symmetries that molecules can possess. We know how to generate the Cartesian representation of any point group, and how to use the representations to visualize pseudo-molecules that possess all the group symmetries. So this is the end of Part I of this book. But we still know nothing about the concepts of subgroup, class, species, or character which make groups so useful in molecular physics. We begin to develop those concepts in the next chapter.
267
20. Subgroups Preliminaries
20.1 Definition of subgroup We begin with the fundamental definition of subgroup, and with two immediate modifications of that concept. Subgroup If G is a group, and if H is a subset of G that obeys all the group axioms, then H is a subgroup of G. The next definition is little more than a linguistic annoyance, a result of the way mathematicians define subsets. (Every set is deemed to be a subset of itself.) Trivial subgroups Every group has two trivial subgroups : (1) The unit element by itself, and (2) The entire group. With the trivia out of the way, we can say what we nearly always mean when we speak of subgroups : Proper subgroup A subgroup that is not a trivial subgroup is a proper subgroup. In other words, proper subgroups are smaller than the full group, but larger than the unit element alone. All this is very nice, but why would a chemist or a molecular physicist bother with it? It is because of the following very practical fact: When a molecule is perturbed, the group generally changes. But there are constraints on how the group can change; the old and new groups are always related by the groupsubgroup relation. If you start with a highly symmetric molecule and exchange one of its symmetric atoms for an atom of another kind (with similar bonding) it is said that the symmetry is “broken” or “lowered” to a subgroup of the original group. Often the lowered symmetry will have new fundamental properties, such as a dipole moment or a transition moment lacking in the original. Thus the symmetry analysis of molecular properties becomes a powerful tool for structural chemisW.M. 269 try. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_20, © Springer Science+Business Media, LLC 2009
If you start with a highly symmetric molecule and exchange one of its symmetric atoms for an atom of another kind (with similar bonding) it is said that the symmetryTheory is “broken” or “lowered” to a subgroup of the original group. Often Symmetry the lowered symmetry will have new fundamental properties, such as a dipole analysis of molecular properties becomes a powerful tool for structural chemistry. On the other hand, if you start with a molecule that has only one atom that prevents its belonging to some group, and if you change that atom appropriately, the symmetry will rise to a higher group that has the lower group as a subgroup. The rest of this chapter is devoted to detailed examples of such simple substitutions, and their consequences in terms of group-subgroup relations between the old and new symmetries.
20.2 A simple but nontrivial example (group C3 h ) 20.2.1 A three-element subgroup of C3 h We look immediately at an example of a proper subgroup. As the main group G we pick group C3 h . Remembering that it is a product group C3 Ä Ch we know right away that both C3 and Ch will be subgroups. To verify, partition its table into 3´3 subtables using a special display operator, NiceTable, defined in the preliminaries : NiceTable@ MultiplicationTable@"C3h"D, 3, 3D E C3 C32 Σh S3 S35
C3 C32 E S3 S35 Σh
C32 E C3 S35 Σh S3
Σh S3 S35 E C3 C32
S3 S35 Σh C3 C32 E
S35 Σh S3 C32 E C3
Group C3 is in the upper left. We check this : NiceTable@ MultiplicationTable@"C3"D, 3, 3D E C3 C32 C3 C32 E C32 E C3
Whenever a group is ordered so that one of its subgroups occurs together at the head of the list, it is very easy to spot that subgroup. The subgroup table is just an upper left section of the whole group table. As a counter-example of a subset that is not subgroup, look at the upper left 4by-4 sub-table of the C3 h table : 270
Example C3h
NiceTable@ MultiplicationTable@"C3h"D, 4, 4D E C3 C32 Σh S3 S35
C3 C32 E S3 S35 Σh
C32 E C3 S35 Σh S3
Σh S3 S35 E C3 C32
S3 S35 Σh C3 C32 E
S35 Σh S3 C32 E C3
The upper left is not a subgroup because it is not a Latin Square, and therefore not a group.
20.2.2 A two-element subgroup of C3 h We know that Ch is a subgroup, but even if we did not, it is easy to spot any subgroups of order 2 : just look for E's on the diagonal. This is the sign of a selfinverse element, and therefore the sign of a 2-element subgroup. In the C3 h case, the reflection Σh is such an element. To make this crystal clear, we permute the elements of C3 h so that elements E and Σh are the first two elements. If you need to refresh yourself on permutations, click here. Note that we permute the names as well as the elements, so that the each name stays with its element. perm = 81, 4, 2, 3, 5, 6<; names = ElementNames@"C3h"DPpermT; mats = CartRep@"C3h"DPpermT; NiceTable@ MultiplicationTable@Dot, mats, namesD, 2, 2D E Σh C3 C32 S3 S35
Σh E S3 S35 C3 C32
C3 S3 C32 E S35 Σh
C32 S35 E C3 Σh S3
S3 C3 S35 Σh C32 E
S35 C32 Σh S3 E C3
The top left is the table for group Ch . NiceTable@ MultiplicationTable@"Ch"D, 2, 2D E Σh Σh E
How many other subgroups are there in C3 h ?
271
Symmetry Theory
On your own Guessing that {E,C3,C32,S3,S35} might be a subgroup, follow the model above, permuting these five elements and their names to the front of the group, and make a multiplication table. Partition it using Nice Table[ …,5,5] . If this does not give a subgroup, try to find others. Now you have tried very hard to find other subgroups of C3 h , and you have not found any. So now you are ready to conclude that C3 and Ch are the only subgroups of C3 h .* Preview of coming attractions A person who knows Lagrange's Theorem (coming in the next chapter) would say instantly that it is impossible for C3 h (six elements) to have a five-element subgroup. How could he possibly know this? You will see. * If you are deeply offended by this, read on.
20.3 Finding all the subgroups of a group Think for a moment about the assertion at the end of the last section, and what level of credence you should give it. Searching for something and failing to find it is not a proof that it is not there, unless you prove formally that you have exhaustively examined all the possibilities. So the claim that we have found all the subgroups of C3 h , as it stands, is mere persiflage. Making certain that you have exhausted all possible candidates for subgroup is tedious, even with the help of Lagrange's Theorem. No one has ever found any algorithm for subgroup extraction other than exhaustive examination, though many have tried. Therefore, we need a tabulation of subgroups, and this is provided in one of the earliest chemistry books to use group theory, Wilson, Decius, and Cross Molecular Vibrations. WD&C tabulate many group-subgroup relations in their Appendix X-8, (Table X-14). To tell the frozen truth, our Subgroups operator relies upon the near-divine authority of WD&C, who in turn rely on many years of hand calculation by 19th century mathematicians. Just a couple of examples : Subgroups@"C2v"D
272
Finding subgroups 8C2, 2 Cv<
Why does it say 2 Cv ? Look at the ElementNames of this group: ElementNames@"C2v"D 8E, C2, Σvzx, Σvyz<
There are two ways to choose a vertical reflection plane to make a subgroup: {E,Σvzx} and {E,Σvyz}. Sometimes the repeats are surprisingly numerous. Subgroups@"D6h"D
8D6, 2 D3h, C6v, C6h, 2 D3d, D2h, C6, C3h, 2 D3, 2 C3v, S6, D2, 2 C2v, 3 C2h, C3, 3 C2, Cv, Ch, Cd, Ci<
Interactive readers can see the subgroups of all our tabulated point groups by processing the following cell : Transpose@ 8GroupCatalog, Map@Subgroups, GroupCatalogD
20.4 An orientation issue There is a tricky issue that you must be aware of in dealing with subgroups. Taking D3 h as the main group, there are a lot of subgroups: Subgroups@"D3h"D
8C3h, D3, C3v, C2v, C3, C2, 2 Ch<
The tricky issue will appear if we look at subgroup C2 v . It has four elements, all of which ought to be in D3 h . But when we ask to see the common elements Intersection@CartRep@"D3h"D, CartRep@"C2v"DD 8881, 0, 0<, 80, -1, 0<, 80, 0, 1<<, 881, 0, 0<, 80, 1, 0<, 80, 0, 1<<<
there are only two. Do Wilson, Decius, and Cross have a mistake in their subgroup tables? Don't bet on it. Group C2 v is pretty simple: Column@RecognizeMatrix CartRep@"C2v"DD 8identity< 8rotation, 2-fold, 880, 0, 1<, Π<< 8reflection, 80, 1, 0<< 8reflection, 81, 0, 0<<
It consists of a twofold rotation and two reflections perpendicular to the rotation axis, and to each other. Now look at D3 h : 273
Symmetry Theory
It consists of a twofold rotation and two reflections perpendicular to the rotation axis, and to each other. Now look at D3 h : Column@RecognizeMatrix CartRep@"D3h"DD 8identity<
:rotation, 3-fold, :80, 0, 1<,
2Π >> 3
:rotation, 3-fold, :80, 0, -1<,
2Π >> 3
8rotation, 2-fold, 881, 0, 0<, Π<< :rotation, 2-fold, ::
:rotation, 2-fold, ::-
1
, 1, 0>, Π>>
3 1
8reflection, 80, 0, 1<<
, 1, 0>, Π>>
3
:rotoreflection, 3-fold, :80, 0, 1<,
2Π >> 3
:rotoreflection, 3-fold, :80, 0, -1<, 8reflection, 80, 1, 0<< :reflection, : :reflection, :
3 2 3 2
2Π >> 3
, - 12 , 0>> ,
1 , 2
0>>
There are three twofold rotation axes, but none is the z axis. One twofold axis is the x-axis. To build a C2 v subgroup on this, we need two reflections, one along z and the other along y. And indeed they are there: {reflection,{0,0,1}} and {reflection,{0,1,0}} . So C2 v really is present inside D3 h , but not in standard orientation.
20.5 Symmetry breaking in PCl5 (group D3 h ) 20.5.1 Phosphorous pentachloride Consider the molecule phosphorous pentachloride, PCl5 . Below, you can see that it is a triangular bi-pyramid. The two axial bonds are a little longer than the three equatorial bonds.
274
PCl5
Isotopically pure
Fig. 20.1 The structure of PI35 ClM5 . The axial bonds are longer than the equatorial bonds.
What are the symmetry elements of the isotopically pure P Cl5 ? (1) The vertical axis Cl - P - Cl is a threefold rotation axis. (2) Each of the three P - Cl bonds in the xy plane is a twofold axis. (3) There is a horizontal reflection plane. (4) The vertical axis is also a three-fold rotoreflection axis. (5) There are three vertical reflection planes. Compare these to the elements of group D3 h : ElementNames@"D3h"D
8E, C3a, C3b, C2a, C2b, C2c, Σh, S3a, S3b, Σva, Σvb, Σvc<
There is an exact match, so isotopically pure P Cl5 belongs to group D3 h . But if we break its symmetry by replacing a 35 Cl atom by a 37 Cl atom, the group must become one of the following : Subgroups@"D3h"D
8C3h, D3, C3v, C2v, C3, C2, 2 Ch<
There are two possibilities : (1) Axial substitution, or (2) Equatorial substitution. We discuss these now in turn.
20.5.2 Axial isotope substitution Axial substitution gives the molecule seen below. The bond distances and bond angles have not changed.
275
Symmetry Theory
Axial isotope
Fig. 20.2 Axial PH37 ClLI35 ClM4
What are the symmetry elements? The principal threefold rotation axis remains; The three vertical reflection planes remain. But the following elements are destroyed: The three twofold horizontal axes; The horizontal reflection plane; The threefold rotoreflection axis. With only a threefold rotation axis and three equivalent vertical reflection planes remaining, this is group C3 v : ElementNames@"C3v"D
8E, C3a, C3b, Σva, Σvb, Σvc<
Good; C3 v was one of the subgroups of D3 h .
20.5.3 Equatorial substitution What happens if the changed atom is equatorial?
276
PCl5
Equatorial naive orientation
Equatorial standard orientation
Fig. 20.3 Equatorial PH37 ClLI35 ClM4 . Left, naïve orientation; Right, standard.
On the left in Fig.20.3 you see PCl5 , changed to include one heavy equatorial atom. But the threefold vertical axis has been destroyed and cannot serve legally as the z axis (Rule 2). The rotation axis of highest order is the x axis in this picture, so we must turn it vertical, as you see on the right. There is no other rotation axis, so Rule 3 does not apply. Rule 4 says that one reflection plane must be the z,x plane, and it is. There are two vertical reflection planes, and we could legally have used the other just as well. (1) The new z axis is a twofold rotation axis. There is no other rotation. (2) There are two reflecting planes (z,x and z,y) intersecting along z. Compare this to ElementNames@"C2v"D 8E, C2, Σvzx, Σvyz<
There is an exact match. Good; C2 v was also was one of the subgroups of D3 h .
20.5.4 Two-atom substitutions P H37 ClL2 I35 ClM3 Here are three easy problems. Click to the answers only to check yourself. Problem 1 Two heavy axial atoms What is the group of PCl5 with two heavy axial isotopes?
277
Symmetry Theory
Two axial isotopes
Fig. 20.4 Diaxial PH37 ClL2I35 ClM3
Click here to check your answer. Problem 2 : Two heavy equatorial atoms What is the group of PCl5 with two heavy equatorial isotopes? Show@npc12D
Two equatorial isotopes
Click here to check your answer. Problem 3 : One axial and one equatorial
278
PCl5
Axial-equatorial standing up
With one heavy axial atom it became C3 v ; with one heavy equatorial atom it became C2 v . But what is it with both? Click here to check your answer.
20.6 Definition of “symmetry breaking” We have now seen examples where isotopic substitution has (1) lowered the symmetry, (2) left the symmetry unchanged, and (3) raised the symmetry. So now we can make a precise statement of what “symmetry breaking” really means. Symmetry breaking When we say that a high symmetry is “broken”, we usually mean that a perturbation has destroyed a symmetry element. Therefore, when the remaining symmetry elements are used to generate a group, the new group can only be a subgroup of the old group. It cannot switch to a new unrelated symmetry. In cases where substitution raises the symmetry (introduces new symmetry elements) the old group is a subgroup of the new group.
279
Symmetry Theory
20.7 End Notes Answer 1 : two heavy isotopes, diaxial Two heavy axial isotopes restore the full symmetry of isotopically pure molecule, D3 h Click back to the top for a blow-by-blow analysis.
Answer 2 : two heavy isotopes, diequatorial It helps a little to rotate by 1/3 turn about z, because that makes the x-axis into a twofold rotation axis (left figure). But the vertical axis has lost its rotation symmetry. Turning the x axis vertical, it is like Fig.20.XXX, except that the altered atoms are below the xy plane instead of above. So the group is again C2 v .
Two equatorial isotopes zx reflection
280
Two equatorial standard orientation
End Notes
Answer 3 : one axial, one equatorial This molecule has one reflection plane and no rotation axis. If you orient it so its plane is zx, it belongs to group Cv ; but Rule 1 says to put the reflection plane horizontal when it is the only symmetry, so it is group Ch .
Axial-equatorial standing up
Axial-equatorial lying down
281
21. Lagrange's Theorem Preliminaries
21.1 Purpose Our goal in this chapter is Lagrange's theorem, a surprising and powerfully useful result about the order of subgroups. It is the earliest result in abstract group theory (ca. 1770), and its beauty and simplicity motivated a great deal of work in this field, before it even was a field. We prove it in 21.5.0, below. But this theorem depends on the concept of cosets, and on a coset lemma. Therefore we must do these first.
21.2 Definition of coset First, a little extension of the meaning of Ä : An element times a group, a Ä H If H is a group of elements 8h1 , h2 , Ñ < and a is an element that multiplies with them, then a Ä H means 8a Ä h1 , a Ä h2 , Ñ <. In Mathematica-talk, this means that the operation Ä is Listable. Now we can define the coset. Actually, there are two kinds, the left coset and the right coset : Cosets, left and right The set of elements in a Ä H is the left coset of H by a; similarly, H Ä a is the right coset of H by a. We will work below only with left cosets, but everything is similar if you switch to right cosets.
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_21, © Springer Science+Business Media, LLC 2009
283
Symmetry Theory
21.3 An operator for cosets We do not know for sure how Lagrange discovered his great coset theorem, but it is likely that once he had the idea of cosets, he did examples on a number of groups that he knew about. We can do such experiments very easily and quickly using Mathematica. We define an operator that make it easy to construct cosets of a subgroup within a group. It is called MakeCoset[groupName,subgroupName,elementName] It converts names to matrices, constructs the coset using the matrices, and then converts the coset matrices back to names : Clear@MakeCosetD; MakeCoset@gpNm_, sbgpNm_, elNm_D := Module@ H*gpN=groupName,
8elMat, sMats, leftCosetMats, cosetNames<, H*Turn the element name into a matrix : *L elMat = elNm . NamesToRepMats@gpNmD; H*Pull out the subgroup matrices: *L sMats = CartRep@sbgpNmD; H*Make the left coset matrices: *L leftCosetMats = Map@elMat.ð &, sMats, 1D; H*Turn the coset matrices into names: *L cosetNames = leftCosetMats . RepMatsToNames@gpNmD D; sbgpN=subgroupName,elN=elementName*L
Note the trailing 1 in the Map operation. This makes it Map at level 1, so that Dot will act on matrices, not matrix elements. Technical note: In the Symmetry` tables, we sometimes give the same matrix a different name in different groups, and that could mess up the experiment. So when we convert matrices to names (or vice-versa) we use the names from the group, not the subgroup.
284
Cosets automated
21.3.1 Make all the cosets of a subgroup We test this operator immediately. We have been using group D3 h as an example, and we continue here. First look at the names of its elements: ElementNames@"D3h"D
8E, C3a, C3b, C2a, C2b, C2c, Σh, S3a, S3b, Σva, Σvb, Σvc<
There are a lot of subgroups to choose from: Subgroups@"D3h"D
8C3h, D3, C3v, C2v, C3, C2, 2 Ch<
We pick C3 because its principal axis, as it sits inside D3 h , is the standard z axis, (If we picked C2 v we would run into trouble because its principal axis, as it sits within D3 h , is the x-axis. Click to review.) ElementNames@"D3h"D
8E, C3a, C3b, C2a, C2b, C2c, Σh, S3a, S3b, Σva, Σvb, Σvc<
First, make a coset based on an arbitrary element of D3 h (namely, "C2c" ): MakeCoset@"D3h", "C3", "C2c"D
8C2c, C2b, C2a<
So MakeCoset seems to work. Since subgroup C3 has three elements, there will always be three elements in any coset of C3 . The experiment is to make as many cosets as possible, reporting the list of cosets made and the list of elements left over. We base it on a While operator, which cycles while some criterion is met, and stops when it is not met. Look at the setup below. The empty cosets list will gradually fill, and the unused list will gradually empty as the operations cycle under While. Every cycle takes the first element from the unused list and makes its coset. That coset is appended to the cosets list and its members are deleted from the unused list. The cycle stops when there are not enough unused elements to make one more coset. H*Setup*L cosets = 8<; unused = ElementNames@"D3h"D; H*Start the cycle*L While@Length@unusedD > 2, 285
Symmetry Theory
newCoset = MakeCoset@"D3h", "C3", unusedP1TD; cosets = Append@cosets, newCosetD; unused = Complement@unused, Flatten@cosetsDD D; 8cosets, unused< 888E, C3a, C3b<, 8C2a, C2c, C2b<, 8S3a, S3b, Σh<, 8Σva, Σvc, Σvb<<, 8<<
On this trial, the 12 elements of D3 h were neatly partitioned into mutually exclusive cosets, with nothing left over. And strangely, when Lagrange tried this on all the groups he knew of, the same thing happened. (1) No element ever appeared in two cosets, and (2) Nothing was ever left over. The first observation became the Coset Lemma, and the second became Lagrange's Theorem. The proofs follow. On your own Try some other groups and subsets. But be aware of the orientation issue. To work with every subgroup, MakeCoset would have to lift its subgroup elements out of the tabulated main group, rather than the tabulated subgroup. By suitable use of RecognizeMatrix you might be able to make this happen. If you enjoy creative programming, try it.
21.4 The coset lemma 21.4.1 Statement and proof
Coset Lemma If two cosets of a proper subgroup have one element in common, then they have all their elements in common. For proof, go through the experiment using general symbols instead of concrete examples, as we did in the experiments. Let the group be {E,A,B,C,… ,R,S,T,… ,Z} and let the subgroup be {E,R,S,T}. First, construct the coset of E and set it aside (it will be the subgroup itself.) Then construct cosets with two elements, A and B, that are in the main group but outside the subgroup. That is, construct AÄ{E,R,S,T} and B Ä{E,R,S,T}. 286
Let the group be {E,A,B,C,… ,R,S,T,… ,Z} and let the Coset subgroup lemmabe E R T E the main group but outside the subgroup. That is, construct AÄ{E,R,S,T} and B Ä{E,R,S,T}. Suppose these two cosets are different, except for one element that they have in common; i.e., suppose for some subgroup element R, it is true that AÄ R = BÄ S. All group elements have an inverse, so we can right multiply by R-1 : A = B Ä S Ä R-1 But S and R and R-1 are all in the subgroup. So also S Ä R-1 must be in the subgroup; call it element T. Then A=BÄT Using this form of A in the calculation of the A coset , it becomes (B Ä T) Ä{E,R,S,T} Now the power of using general symbols kicks in. We regroup as B Ä (T Ä{E,R,S,T})} By the rearrangement theorem, T Ä{E,R,S,T}contains the same elements as {E,R,S,T}, but in a different order. So the A and B coset lists are the same except for order. But order does not matter in a set, so the two cosets are identical. Therefore, if two cosets have one element in common, they have all their elements in common. Which was to be shown.
21.4.2 A diagram for the lemma Below is a diagram of the situation described the Coset Lemma, with big group G and subgroup S, and cosets AÄS and BÄS. If there are other cosets, consider them to be shown similarly. The main point is, by the Coset Lemma, the cosets have no points in common.
Q
E G
S AÄS
A
BÄS B
But this diagram also raises a question. If subgroup S contains m elements, then all its cosets also contain m elements, and if it is possible to form n cosets, the total number of elements in cosets is m*n. But suppose that the number of elements in big group G is m*n+1, with orphan element Q left out of all cosets.287 Lagrange's experiments never found such a Q, but that does not prove that
Symmetry Theory
But this diagram also raises a question. If subgroup S contains m elements, then total number of elements in cosets is m*n. But suppose that the number of elements in big group G is m*n+1, with orphan element Q left out of all cosets. Lagrange's experiments never found such a Q, but that does not prove that somewhere out there is a peculiar group that does possess an orphan Q. Linguistic note: Long ago, the word "factored" meant "separated into parts". Today it means almost exclusively "separated into parts that multiply together to make the whole". But in Lagrange's time it had not yet drifted toward this meaning. So when Lagrange divided a group into cosets, he said he had "factored" it. This usage persists to this day in many statements of LaGrange's Theorem. Don't let it confuse you.
21.5 Lagrange's theorem proved
Lagrange's theorem If G is a group and S is a subgroup of G, the group order of S is an exact divisor of the group order of S. The formal proof is pretty easy in the light of the Coset Lemma. Let G be a group of order g, and let S be a subgroup of G, of order s.
Suppose that when G has been partitioned into as many cosets as possible, there is one element Q left over. But nothing prevents us from making the coset of Q, and when we do it will contain s elements, just like any other coset. This means it must contain Q plus other elements already in one of the cosets. But the coset lemma says this is impossible, so the existence of leftover element Q is a contradiction. There are never any leftover elements. Let c be the number of cosets. Since every coset contains s elements, it must be that c*s = g, the total number of elements. Thus integer c is g/s. In other words, the number of subgroups s is an exact divisor of the order of the main group g, which was to be shown.
21.5.1 Check the Symmetry` package tabulations If we divide the order of the main group by a list of the orders of all its subgroups, we should get a list of integers. Try it :
288
Lagrange's theorem
GroupOrder@"D6d"D Map@GroupOrder, Subgroups@"D6d"DD :2, 2, 4, 3, 4, 4, 6, 6, 6, 8,
24 2 + C2
, 12>
On Your Own It almost works. Can you fix it? It may need a Module.
21.5.2 Groups of prime order: a corollary
A corollary of Lagrange's theorem Groups of prime order have no proper subgroups. Thus it is useless to look for the proper subgroups of group C5 , for instance, because it has five elements, and 5 is a prime number. Prime numbers, by definition, have no divisors other than themselves and 1.
21.5.3 A caution Suppose you find a group with 28 elements. In examining it for subgroups, what orders might be expected? Divisors@28D
81, 2, 4, 7, 14, 28<
Any of these divisors might be the order of a subgroup, but it does not have to be. There is no requirement that each divisor has to correspond to a subgroup, except for the two trivial subgroups with orders 28 and 1.
289
22. Classes Preliminaries
22.1 Qualitative meaning of classes In this chapter we will construct operator named MakeClass that will separate the elements of any group of elements into “classes” of similar elements. We demonstrate it immediately : Classify@CartRep@"C3v"DD . RepMatsToNames@"C3v"D 88E<, 8Σvc, Σvb, Σva<, 8C3a, C3b<<
The identity E, the three Σv reflections, and the two C3 rotations constitute the three classes of group C3v. And indeed,the elements in each class seem intuitively “ similar” to each other. How did it perform this trick? Be assured Classify did not use the name similarities to classify them. It would have separated rotations from reflections no matter what the names were. Also, it did not use any specific geometric properties to classify them. All groups have classes, even those with no geometrical meaning.
22.2 Graphics of two "similar" elements In Chapter 4 we showed a before- and after- picture of the ammonia molecule in its standard position, undergoing a Σv reflection (in the zx plane). Also we showed the potential due to the three H atoms of ammonia, a function with C3 v symmetry. Now we show a sequence of operations that performs a reflection in a plane that is not used directly :
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_22, © Springer Science+Business Media, LLC 2009
291
Symmetry Theory
1. Before
2. After C3inv
3. After Σzx . C3inv
4. After C3 . Σzx . C3inv
Fig. 22.1 Two similar reflections in group C3 v
Starting from original position in the upper left, we first rotate clockwise by 1/3 turn (After C3inv), then we reflect in the colored zx plane (After Σzx.C3inv), then we back-rotate both the molecule and the colored plane (After C3.Σzx.C3inv). Comparing H atom numbers in the first and last pictures, the overall operation is simply reflection in the rotated plane. This is an illustration of a very general principle. In any compound operation of the type U.V.U-1 , operation U-1 first transforms the molecule, then V performs some other transform, and then U undoes the original transform both on the molecule and on the symmetry element used by V (above, the reflection plane shown). The final result is the transform of the molecule by a symmetry element similar to V, but in a different orientation. U.V.U-1 is called a “similarity transform” of V by U It seems natural to say that V and U.V.U-1 are elements in the same “class".
292
Find similarities
22.3 Finding all the similar elements 22.3.1 All the reflections of group C3 v Let's repeat this "experiment" keeping the central Σva operator, but using another element in the place of the C3 a rotation. In fact, it is easy to do it for all the elements in the group at once. We just Map the triple product mat.C3 a . mat-1 onto every mat in the group. mats6 = Map@Hð.Σzx .Inverse@ðDL &, CartRep@"C3v"DD . RepMatsToNames@"C3v"D
8Σva, Σvc, Σvb, Σva, Σvc, Σvb<
They are all reflections, named Σ-something. So the operation mat.reflection.mat-1 produces only reflections as mat runs over the whole group! Six reflections are generated as mat runs over the six elements of the group. But the group contains only three reflections, so there must be repeats. We cut them away with Union : Union@mats6D
8Σva, Σvb, Σvc<
So we have created an operator which, when applied to a whole group, selects out just the vertical reflections of the group. Can we do the same thing for rotations?
22.3.2 All the rotations of group C3 v We do the same thing again, but this time using one of the rotations as the central element of the operator sandwich. This time, we put Union right into the operator to eliminate repeats automatically : rotMat = "C3a" . NamesToRepMats@"C3v"D; Map@Hð.rotMat.Inverse@ðDL &, CartRep@"C3v"DD . RepMatsToNames@"C3v"D Union 8C3a, C3b<
It did it again! As mat runs over the whole group, the operation mat.rotMat.mat-1 293 produces all the group elements that are rotations by multiples of 1/3 turn about the z axis.
Symmetry Theory
It did it again! As mat runs over the whole group, the operation mat.rotMat.mat-1 produces all the group elements that are rotations by multiples of 1/3 turn about the z axis.
22.4 Definition of class This is enough to motivate a formal definition : Definition of class The class of element x in group G is the set of elements generated by m.x.m-1 as m runs over all the elements of group G. Alternative statement:
C[x] = Xm.x.m-1 \ " m in G The script capital C means “class”. The " symbol is read by mathematicians as “ for all”, and in this book the pointed brackets X… \ encloses a “ set”. A set is like a List, except that no ordering is implied and no repeats are allowed. The Symmetry` package has an operator that creates classes by an algorithm based directly on this definition. We discuss it next.
22.5 A very pregnant little discussion Now that you know what a similarity transform is, and what classes are, you should click into the MatrixReview and read an amazing little discussion there. It shows that entire theories can be similarity transformed, sometimes with an important simplification. It is summarized with a metaphor: "… similarity transforms change the costumes of vectors and matrices, but underneath the costumes they remain the same troupe of clowns, and they perform the same show." If you can't recognize a clown by his costume, how do you recognize him? You have to do it by his character, the kind of role he plays in the show. The character table divides the clowns into classes on the basis of their characters, and tells how many belong to each class. Every troupe has a unique character table. So if you have a set of character tables for different troupes, you can always tell which you are looking at, whatever their costumes happen to be. 294
22.6 Operator MakeClass
Class tables
22.6 Operator MakeClass The definition of class has been embodied as a Symmetry` package operator called MakeClass. The thumbnail sketch is MakeClass[el (, grp)] returns the class of element el within group grp. Element el may be a matrix or a matrix name, and grp may be a group of matrices or a group name. The default for grp is $DefaultGroup.
We use this operator to quickly review the results we got above :
MakeClass@"C3a", "C3v"D . RepMatsToNames@"C3v"D
8C3a, C3b<
MakeClass@"Σva", "C3v"D . RepMatsToNames@"C3v"D
8Σvc, Σvb, Σva<
Fine, it does what it should. Try it now on a bigger group with a lot more possibilities, the octahedral group O . We will see a little surprise at the end. ElementNames@"O"D
8E, C3mmm, C3mmp, C3mpm, C3mpp, C3pmm, C3pmp, C3ppm, C3ppp, C2x, C2y, C2z, C4xm, C4xp, C4ym, C4yp, C4zm, C4zp, C2mxy, C2myz, C2mzx, C2pxy, C2pyz, C2pzx<
MakeClass@"E", "O"D Map@RecognizeMatrix, ðD &
88identity<<
The class of the identity is just the identity itself. Now make the class of a threefold rotation, and use RecognizeMatrix to see what kinds of transforms are in the class : MakeClass@"C3mmm", "O"D Map@RecognizeMatrix, ðD &
::rotation, 3-fold, :81, -1, 1<,
2Π
>>, :rotation, 3-fold, :8-1, 1, 1<,
3 :rotation, 3-fold, :81, -1, -1<,
2Π
2Π
>>, :rotation, 3-fold, :8-1, -1, 1<,
2Π
3 :rotation, 3-fold, :8-1, 1, -1<,
2Π 3
:rotation, 3-fold, :81, 1, -1<,
2Π 3
>>,
3 >>,
3 >>, :rotation, 3-fold, :81, 1, 1<,
2Π
>>,
3
>>, :rotation, 3-fold, :8-1, -1, -1<,
2Π
>>>
3
They are all threefold rotations. Try the class generated by a fourfold rotation : 295
Symmetry Theory
MakeClass@"C4xm", "O"D Map@RecognizeMatrix, ðD & ::rotation, 4-fold, :80, 0, 1<,
Π
:rotation, 4-fold, :80, 1, 0<,
2 Π
:rotation, 4-fold, :81, 0, 0<,
2 Π
>>, :rotation, 4-fold, :80, -1, 0<,
Π
>>,
>>, :rotation, 4-fold, :80, 0, -1<,
2 Π
>>,
>>, :rotation, 4-fold, :8-1, 0, 0<,
2 Π
>>>
2
2
They are all four-folds, as you might expect. Now generate the class of the twofold rotation named C2x : MakeClass@"C2x", "O"D Map@RecognizeMatrix, ðD &
88rotation, 2-fold, 880, 0, 1<, Π<<, 8rotation, 2-fold, 880, 1, 0<, Π<<, 8rotation, 2-fold, 881, 0, 0<, Π<<<
There are only three members; that is a bit of a surprise. The two-fold named C2mxy , among others, is missing above. What is its class? MakeClass@"C2mxy", "O"D Map@RecognizeMatrix, ðD &
88rotation, 2-fold, 880, -1, 1<, Π<<, 8rotation, 2-fold, 880, 1, 1<, Π<<, 8rotation, 2-fold, 88-1, 1, 0<, Π<<, 8rotation, 2-fold, 88-1, 0, 1<, Π<<, 8rotation, 2-fold, 881, 0, 1<, Π<<, 8rotation, 2-fold, 881, 1, 0<, Π<<<
The first class of 2-folds rotates around the coordinate axes ; the second, around dihedral axes that lie between two coordinate axes. The two classes are “pretty similar”, but not similar enough. To put them in the same class, the group would have to contain rotations around the coordinate axes by Π/4. In group theory, never trust simplistic statements. It just takes too many words to cover all possibilities, so some things people say informally (like qualitative explanations of “similar") are mostly true, but not precisely true.
22.7 Table lookup operators for classes The group tables in the Symmetry` package know all about classes. If you know the name of a group, and if it is tabulated, there is a shortcut around MakeClass The tetrahedral group Td is a good illustration : Classes@"Td"D
88E<, 8C3a, C3b, C3c, C3d, C3e, C3f, C3g, C3h<, 8C2a, C2b, C2c<, 8S4a, S4b, S4c, S4d, S4e, S4f<, 8Σda, Σdb, Σdc, Σdd, Σde, Σdf<<
The 24 elements of the group form five classes. They need names, which have to be tabulated, like all conventions :
296
Clowns
ClassNames@"Td"D 8E, C3, C2, S4, Σd<
How many elements are there in each class? ClassPopulations@"Td"D 81, 8, 3, 6, 6<
This kind of data is available for every tabulated group. Change the group name and go through all the operations again. You will see.
22.8 Theorems about classes The little calculation-experiments above illustrate several points that are true for the classes of every group. These points are stated as the five theorems below. The proofs are easy; you start them all by writing down the definition of class and staring at it, while you think about how to use the special condition mentioned in the theorem. Then start to calculate. Proving these theorems for yourself will help to fix the definition of class in your mind, which you MUST do. Class is a central concept in the physical applications of group theory, and will reappear many times throughout the rest of this book. 1. Every element belongs to the class that it generates. Write the definition down and think through the details of what happens when the definition is set equal to the middle element in the triple product. The proof is a one-liner.
2. In every group, the unit element E forms a class by itself. Again, the proof is a one-liner, based on a special thing that happens when the triple product is evaluated with an E in the center.
3. No element belongs to two classes. This one is just a little harder. Write two equations expressing the idea that element Q is a member of two different classes. Then eliminate Q and work until you find a contradiction. If it takes more than a few minutes, click here. But remember: No pain, no gain.
297
Symmetry Theory
4. Classes are invariant under similarity transforms. Another statement, using more words: Let ai be any member of class A. Then subject ai to a similarity transform by g, any member of the group. The result will be in class A. Put the definition of class together with Theorem 1, above. But to see it argued in detail, click here.
5. Every class of a product group is the outer product of two classes of the generating groups. Click back to the definition of the product group. The proof is a straightforward manipulation of symbols, but if you gotta have it, click here.
22.9 Class character, and other class properties In Appendix A3, the MatrixReview, it is shown that if two matrices M and N are in the same class, then M and N have several properties in common. So all the matrices in the class have these properties in common. The proofs of these common properties are not difficult, but we prefer to keep them all together in the MatrixReview. We quote the most important one : 6. Every matrix in a class has the same trace. The trace of a transform matrix is called its character. It is very likely you can prove this for yourself. Write the reputed property Trace@MD=TraceBQ.M.Q-1 F
in index notation, and rearrange the order of summation. Use the fact that Q is unitary. It really is not that hard. But if you just can't wait to see the proof, click here. It is hard to overestimate the importance of this theorem. Applied group theory revolves around the “character table” for the group, which gives the values of the class characters of all the inequivalent irreducible representations of the group for all classes of the group. The italicized words have not yet been explained in this book, so this statement may not be crystal clear to you. But the full explanation lies in the chapters just ahead. Take this as motivation for 298 learning what inequivalent irreducible representations are.
It is hard to overestimate the importance of this theorem. Applied group theory revolves around the “character table” for the group, which givesClass the values of Theorems the class characters of all the inequivalent irreducible representations of the explained in this book, so this statement may not be crystal clear to you. But the full explanation lies in the chapters just ahead. Take this as motivation for learning what inequivalent irreducible representations are. 7. Every matrix in a class has the same eigenvalues. We have already used the eigenvalues of transform matrices as a key ingredient in the operator RecognizeMatrix. The proof that eigenvalues are a common property of the class is not quite as elementary as usual. That is why it lives in the MatrixReview as one of a chain of theorems about class invariant properties. We explored the uses of the eigenvalues very thoroughly in Chapter 13, and used them in the operator RecognizeMatrix. So this is also a theorem of great importance. But note that Theorems 6 and 7 do not say that different classes must have different traces or different eigenvalues. It is easy to prove this by example. Group O contains elements C2x and C2mxy , twofold rotations that belong to different classes. Element C2x belongs to class C2 C2Mat = CartRep@"C2x", "O"D
881, 0, 0<, 80, -1, 0<, 80, 0, -1<<
but element C2mxy belongs to class C2d : C2dMat = CartRep@"C2mxy", "O"D
880, -1, 0<, 8-1, 0, 0<, 80, 0, -1<<
Look at their eigenvalues:
Map@Eigenvalues, 8C2Mat, C2dMat
88-1, -1, 1<, 8-1, -1, 1<<
Look at their traces:
Map@Spur, 8C2Mat, C2dMat
8-1, -1<
So sometimes different classes have the same eigenvalues and the same trace.
299
Symmetry Theory
22.10 The Classify operator In your work with molecules you may well need to work with a group for which no character table exists (very likely, a permutation group), so you will need to divide the group into classes on your own. For this purpose, it will be very useful to have an operator that “classifies” groups automatically. Classify is just an extension of the MakeClass operator. We make a classList which is initially empty, and a freeList which initially has the whole group in it. We take the first element from freeList and construct its class. All the elements in the class are then removed from freeList and (grouped as a sublist) put into the classList. This procedure recycles until freeList is empty. To see the text of it, click here and you will go right into the Symmetry` package to have a look. We try it on our familiar example, group C3 v , using the tabulated xyz representation of the group : classesC3 v = Classify@CartRep@"C3v"DD . RepMatsToNames@"C3v"D 88E<, 8Σvc, Σvb, Σva<, 8C3a, C3b<<
Lovely; it works. We give it one more test. Group Td has lots of classes: ClassPopulations@"Td"D Sort 81, 3, 6, 6, 8<
Now let's see if Classify can produce the same answer by calculation, working on the standard tabulated matrices for group Td . This table is kept under the name CartRep["Td"] : TdClassified = Classify@CartRep@"Td"DD . RepMatsToNames@"Td"D 88E<, 8C2a, C2c, C2b<, 8S4d, S4c, S4b, S4f, S4e, S4a<, 8Σde, Σdd, Σda, Σdb, Σdf, Σdc<, 8C3c, C3b, C3a, C3e, C3d, C3h, C3f, C3g<<
Map@Length, TdClassifiedD Sort
81, 3, 6, 6, 8<
It agrees.
300
22.11 Isomorphisms among order 6 point groups
Classify
22.11 Isomorphisms among order 6 point groups Several point groups in the standard tables are isomorphic to each other. We would like to find them by examining their class structure. We begin by looking at the names of all the tabulated point groups : groupNames = GroupCatalog
8C1, C2, C2h, C2v, C3, C3h, C3v, C4, C4h, C4v, C5, C6, C6h, C6v, Ch, Ci, D2, D2d, D2h, D3, D3d, D3h, D4, D4d, D4h, D5, D5d, D5h, D6, D6d, D6h, I, O, Oh, S4, S6, S8, T, Td, Th<
What is the order of each of these groups? That is, how many elements does each of these groups possess? To make the result more readable we group names and orders together : allpairs = Transpose@8orders, groupNames
881, C1<, 82, C2<, 82, Ch<, 82, Ci<, 83, C3<, 84, C2h<, 84, C2v<, 84, C4<, 84, D2<, 84, S4<, 85, C5<, 86, C3h<, 86, C3v<, 86, C6<, 86, D3<, 86, S6<, 88, C4h<, 88, C4v<, 88, D2d<, 88, D2h<, 88, D4<, 88, S8<, 810, D5<, 812, C6h<, 812, C6v<, 812, D3d<, 812, D3h<, 812, D6<, 812, T<, 816, D4d<, 816, D4h<, 820, D5d<, 820, D5h<, 824, D6d<, 824, D6h<, 824, O<, 824, Td<, 824, Th<, 848, Oh<, 860, I<<
The groups that have order 6 are :
order6pairs = Select@allpairs, MatchQ@ð, 86, _
order6names = Transpose@order6pairsDP2T 8C3h, C3v, C6, D3, S6<
The populations of the classes of these groups are Column@Transpose@ 8order6names, ClassPopulations order6names
The five groups of order 6 appear to be of two different types: One type has six classes (each class containing a single element, clearly); the other type has three classes. We look more closely at the two groups that have three classes; 301 namely, C3 v and D3 :
Symmetry Theory
The five groups of order 6 appear to be of two different types: One type has six three classes. We look more closely at the two groups that have three classes; namely, C3 v and D3 : MultiplicationTable@"C3v"D MatrixForm E C3a C3b Σva Σvb Σvc
C3a C3b E Σvc Σva Σvb
C3b E C3a Σvb Σvc Σva
Σva Σvb Σvc E C3a C3b
Σvb Σvc Σva C3b E C3a
Σvc Σva Σvb C3a C3b E
E C3a C3b C2a C2b C2c
C3a C3b E C2c C2a C2b
C3b E C3a C2b C2c C2a
C2a C2b C2c E C3a C3b
C2b C2c C2a C3b E C3a
C2c C2a C2b C3a C3b E
MultiplicationTable@"D3"D MatrixForm
These tables have the same form. To make this perfectly explicit, we recalculate the two tables using exactly the same list of element names, and ask if the two tables are equal : sixNames = 8"E", "A", "B", "C", "D", "F"<; mtC3v = MultiplicationTable@ Dot, CartRep@"C3v"D, sixNamesD; mtD3 = MultiplicationTable@Dot, CartRep@"D3"D, sixNamesD; mtC3v == mtD3 True
To an abstract group theorist, groups C3v and D3 are “ the same”, because their multiplication tables are the same. But to a symmetrician, they are quite different. In group C3 v , the classes are E, C3 , and Σv , while in group D3 the classes are E, C3 , and C2 . Classes E and C3 are the same in both groups, but Σv is a class of vertical reflections, while class C2 is a class of horizontal twofold rotations. These are two very different symmetry groups which happen to be isomorphic. Now we turn to the other three groups of order 6, each of which has 6 classes (each class containing a single element). They were C6, S6, and C3h. We now show that these are all cyclic groups of order 6 : MultiplicationTable@Dot, CartRep@"C6"D, sixNamesD MatrixForm
302
Classify
E A B C D F
A B C D F E
B C D F E A
C D F E A B
D F E A B C
F E A B C D
The cyclic nature of the group is apparent in the pure counter-diagonals of the multiplication table. (They mean that each row is a one-place rotation of the one above it.) If you do the same thing with either group S6 or C3h, you will not see the pure counter-diagonals. However, this is only because the conventional ordering of these groups does not follow cyclic order. If we reorder them appropriately (starting always with the unit element, and going cyclically from there) and then compute their tables, the pure counter-diagonals appear : S6Reordered = CartRep@"S6"DP81, 6, 2, 4, 3, 5
:rotoreflection, 6-fold, :80, 0, 1<, :rotation, 3-fold, :80, 0, 1<, 8inversion<
2Π >> 3
:rotation, 3-fold, :80, 0, -1<,
2Π >> 3
Π >> 3
:rotoreflection, 6-fold, :80, 0, -1<,
Π >> 3
mtS6 = MultiplicationTable@Dot, S6Reordered, sixNamesD; mtS6 MatrixForm E A B C D F
A B C D F E
B C D F E A
C D F E A B
D F E A B C
F E A B C D
So group S6 is a cyclic group, based on a sixfold rotoreflection.. Now do C3h. C3hReordered = CartRep@"C3h"DP81, 5, 3, 4, 2, 6
:rotoreflection, 3-fold, :80, 0, 1<, :rotation, 3-fold, :80, 0, -1<,
2Π >> 3
2Π >> 3
303
Symmetry Theory 8reflection, 80, 0, 1<<
:rotation, 3-fold, :80, 0, 1<,
2Π >> 3
:rotoreflection, 3-fold, :80, 0, -1<,
2Π >> 3
MultiplicationTable@Dot, C3hReordered, sixNamesD MatrixForm E A B C D F
A B C D F E
B C D F E A
C D F E A B
D F E A B C
F E A B C D
So they are both sixfold cyclic groups, but they differ in the nature of what is cycling. In group C6 , it is a sixfold rotation. In group S6 it is a sixfold rotoreflection. In group C3 h it is a threefold roto-reflection. The latter group is NOT named S3 because Schönfliess declared odd indices in Sn groups to be verboten. On your own This kind of analysis can be applied to groups of any order. Do another order . Pick an easy one; not too large.
A theorem of your very own Put the concept of Abelian groups together with the concept of class, and prove something about the classes of Abelian groups. If you succeed, you may name this theorem after yourself. For a calculational clue, try MakeClass on an Abelian group. Probably you will see it; but still, just in case ...
304
Isomorphisms
22.12 End notes 22.12.1 Proof of Theorem 1 Every element belongs to the class that it generates : When mat runs over the whole group, mat will eventually be the unit matrix E, and then mat.X.mat-1 will give X.
22.12.2 Proof of Theorem 2 When X is E, you can write mat.E.mat-1 = mat.mat-1 = E, regardless of what mat is. So as mat runs over the whole group, E is the only element generated.
22.12.3 Proof of theorem 3 We assume that there exists a questionable element Q that belongs to the class of X and to the class of Y, where X and Y are in different classes. If this is true, there exist elements M and N such that Q = M.X.M-1 and Q = N.Y.N-1 . But if so, we can eliminate Q and rearrange to yield X = M-1 .N.Y.N-1 .M
However, IM-1 .NM.IN-1 .MM = E, so (M-1 .N) and (N-1 .M) are mutually inverse, and may be symbolized by U and U-1 . Therefore X = U.Y.U-1 and X and Y are therefore in the same class, contrary to assumption. Therefore, there exists no element Q belonging to two different classes.
305
Symmetry Theory
22.12.4 Proof of Theorem 4 Let am and an be two different elements of class A. Let g be any element of the group, and consider g am g-1 and g an g-1 . By the definition of class they are still in class A. But is it possible that they are the same? No, because, if g am g-1 = g an g-1 we could left multiply each side by g-1 and right multiply each side by g and we would have am = an , which contradicts the assumption that am and an are different. So the similarity transform of any class produces only elements in the class, with no repeats. (The element order will generally change, but that makes no difference in a set.) So classes are invariant under similarity transforms, which was to be proved.
22.12.5 Proof of Theorem 5 Prove: If AB is a product group, the class of element AB is the class of element A times the class of element B. The class of element ABi is the set YABm Ä ABi Ä AB-1 m for all m]. But ABm
was some product AΑ ÄBG , and ABi was some product AΒ ÄBD . Therefore the class of ABi is YHAΑ ÄBG L ÄHAΒ ÄBD L ÄHAΑ ÄBG L-1 for all Α and G]
or expressing the inverse in more detail,
-1 YHAΑ ÄBG L ÄHAΒ ÄBD L ÄIB-1 G ÄAΑ M for all Α and G]
Since Ä is associative, the parentheses may be removed, leaving -1 YAΑ ÄBG ÄAΒ ÄBD ÄB-1 G ÄAΑ for all Α and G]
But all A and B matrices commute, so commuting the A's leftward and the B's rightward, (but never passing an A through an A or a B through a B) we arrive at YAΑ ÄAΒ ÄAΑ-1 for all Α] ÄYBG ÄBD ÄBG -1 for all G] But this is just the direct product of the class of AΒ and the class of BD , the factors of element ABi , which was to be proved.
22.12.6 Proof of Theorem 6 Prove: The trace of the product is the product of the traces. We want an expression for the trace of ABm . But ABm was some product AΑ ÄBG , and ABn was some product AΒ ÄBD . So we are looking for the trace of 306 AΑ Ä BG Ä AΒ Ä BD ; or equivalently, by permitted commutation, the trace of AΑ Ä AΒ Ä BG Ä BD
Isomorphisms
We want an expression for the trace of ABm . But ABm was some product AΑ ÄBG , and ABn was some product AΒ ÄBD . So we are looking for the trace of AΑ Ä BG Ä AΒ Ä BD ; or equivalently, by permitted commutation, the trace of AΑ Ä AΒ Ä BG Ä BD
But suppose element AΑ is represented by matrix AHΑL _,_ ; element BG by matrix
HΑL HDL BHGL _,_ ; element AΒ by matrix A_,_ ; and element BD by matrix B_,_ . Then the
desired trace, in index notation, is HΒL HGL HDL AHΑL p,q Aq,r Br,s Bs,p We want an expression for the trace of ABm . But ABm was some product AΑ ÄBG , so in double index notation it is ABΑ,G .
Suppose element AΑ is represented by matrix AHΑL _,_ ; element BG by matrix
HΑL HDL BHGL _,_ ; element AΒ by matrix A_,_ ; and element BD by matrix B_,_ . Then the
desired trace, in index notation, is HGL AHΑL p,q Bq,p
22.12.7 Classes of Abelian groups In Abelian groups you are allowed to rearrange multiplications, so Y.X.Y-1 = X.IY.Y-1 M = X.E = X As Y runs over the whole group it gives nothing but X, so in an Abelian group every element is a class by itself. This is the theorem. If you had to read this, it is not your theorem.
307
23. Symmetry and quantum mechanics Preliminaries
23.1 Transformation of eigenfunctions 23.1.1 The Hamiltonian symmetry theorem We have defined geometric and algebraic symmetry, we have shown that the transforms of symmetric objects always come in groups, and we are now ready to think about how these concepts apply to Schrödinger's eigenequation, the basis of quantum chemistry and solid state physics. This equation is H [Ψi ] = Ei Ψi
(23.1)
where H is a Hamiltonian operator for the molecule, Ψi is its wave function for eigenstate i, and Ei is the energy of eigenstate i. Such solutions are called stationary states because all their physical properties (not just the energy) are constant in time. Stable molecules in a bottle have time-independent properties because they are all in or very close to an eigenstate; namely, the one that has the lowest energy, the ground state. We do not yet specify exactly what H is, because it has numerous levels of approximation, and we want to discuss a feature that applies to all of them. H and Ψi are defined in a coordinate space that gives the positions of all the particles that make up the system. Let T be a coordinate transform defined in this space, and apply it to both sides of Eq.23.1 : T [H [Ψi ] ] = T [Ei Ψi ]
(23.2)
The T transforms everything within its scope of operation, so this is the same as T [H ][T [Ψi ] ] = T [Ei ] T [Ψi ]
(23.3)
The term T [Ei ] is nothing but Ei , because Ei has no particle coordinates in it, and cannot be transformed by T . So we have T [H ][T [Ψi ] ] = Ei T [Ψi ]
(23.4)
We are interested in symmetry transforms of the Hamiltonian. By the basic definition of symmetry, these are transforms that leave the Hamiltonian unchanged : T [ H] = H
(23.5)
so that Eq.23.4 becomes W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_23, © Springer Science+Business Media, LLC 2009
309
Symmetry Theory
so that Eq.23.4 becomes H [T [Ψi ] ] = Ei T [Ψi ]
(23.6)
Comparing this to the original Schrödinger equation H [Ψi ] = Ei Ψi , we notice that T [Ψi ] is playing the role of Ψi in the original equation, which means that T [Ψi ] is an eigenfunction of H with eigenvalue Ei . This is profound. We encapsulate it as the Hamiltonian symmetry theorem : If H[ Ψi ] = Ei Ψi , and if T [ H] = H, then T [Ψi ] is an eigenfunction of H with eigenvalue Ei . Immediate comment: Yes, an eigenfunction; but sometimes, another linearly independent eigenfunction. This theorem has very different consequences depending on whether only one linearly independent eigenfunction exists at the given energy, or whether there are several different such eigenfunctions. There is a word that everybody uses to describe this : If an energy level possesses more than one linearly independent eigenfunction, it is said to be degenerate. Otherwise, nondegenerate. In the nondegenerate case, transform T just gives back the same eigenfunction it operated on, possibly with a different phase factor ãä Φ . But if the level is degenerate, it may return a completely different (a linearly independent) eigenfunction with the same eigenenergy. Thus, in degenerate levels, the symmetry transforms T of the Hamiltonian can make new eigenfunctions out of old ones. It's like magic.
310
Transformation of eigenfunctions
23.1.2 A figure for the theorem Benzene is a hexagonal ring molecule C6 H6 (group D6 h ) with a delocalized electron density function that extends around the ring of C atoms. We can approach it through an exactly soluble idealized model: Let six positively charged centers be arranged hexagonally, and consider the stationary wave functions that a single electron might have in the vicinity of the six attractors. (Such one-electron wave functions are called “ orbitals”.) Orbitals are the solutions of Schrödinger's eigenequation, and for one particle they can be found as accurately as desired using known numerical techniques for solving differential equations. The function ΨE1g a [x,y,z], defined in the preliminaries, resembles such an eigenfunction in all its essentials. If you want to see the formula, issue ΨE1ga. It looks complicated to a human, but not to Mathematica. The left side of the next figure is an x,y contour plot of ΨE1g a . It belongs to a degenerate level, so the theorem says we might generate a linearly independent partner by simply letting a D6 h transform work on it. The right side of the figure is such a transform, to be picked by you. Group D6 h has 24 elements, and below you can set the transform number Tnbr to be anything from 1 to 24. The appropriate transform rule will be looked up and applied to ΨE1ga , and the contour plot will be shown on the right. Do the next cell before you start making figures. It will help you to choose and understand the results. Transpose@8Range@24D, ElementNames@"D6h"D
881, E<, 82, C6a<, 83, C6b<, 84, C3a<, 85, C3b<, 86, C2<, 87, C2pa<, 88, C2pb<, 89, C2pc<, 810, C2ppa<, 811, C2ppb<, 812, C2ppc<, 813, inv<, 814, S3a<, 815, S3b<, 816, S6a<, 817, S6b<, 818, Σh<, 819, Σda<, 820, Σdb<, 821, Σdc<, 822, Σva<, 823, Σvb<, 824, Σvc<<
Put in values for Tnbr and Enter until you see what is going on.
311
Symmetry Theory
Tnbr = 3; left = Show@cpBlue@ΨE1ga . z ® 0.1`D, PlotLabel ® "ΨE1ga ", BaseStyle ® 8"TR", 9
ΨE1ga
:rotation, 6-fold, :80, 0, -1<,
Π 3
>>
Fig. 23.1 The Hamiltonian symmetry theorem using Tnbr = 3, a rotation by 2Π/6, showing linear independence.
Some transforms will be linearly dependent, and some not. If normalization is maintained, linear dependence on a single real function means multiplication by ±1, so the whitest atom must stay where it is, or move diametrically across the ring. If some other atom becomes the whitest atom, the two orbitals are linearly independent.
ΨE1ga
8inversion<
Fig. 23.2 Using Tnbr = 13 (the inversion) we see linear dependence.
All these orbitals are antisymmetric for reflection in the plane of the molecule (Tnbr = 18). This means that the orbitals are exactly zero in the plane, so the diagrams are drawn for a cross section slightly above the plane, at z = 0.1 . If you think the white spot should have moved across the ring above, you are thinking of 2D inversion. No, it's 3D inversion; the white spot comes across the ring and up from below. 312
All these orbitals are antisymmetric for reflection in the plane of the molecule (Tnbr = 18). This means that the orbitals are exactly zero in orbitals the plane, so the Delocalized of benzene
thinking of 2D inversion. No, it's 3D inversion; the white spot comes across the ring and up from below.
23.2 Delocalized orbitals of benzene Here is a somewhat untraditional, but very instructive diagram for the Π orbitals of benzene. Energy runs vertical on this diagram, so orbitals on the same level all have the same energy. There are an infinity of orbitals on each degenerate level, but we show just three on each level, constructed by rotational transforms, as in the last section.
Fig. 23.3 A few benzene orbitals. Top and bottom rows are nondegenerate. The middle two rows are degenerate, but the orbitals shown are not orthogonal. They are related by rotations through 1/3 turn. An extra white dot resolves orientational ambiguity for species E2 u .
The orbitals resemble standing waves in a hexagonal pond of water excited by disturbances of the right symmetry. This does not exhaust the games you can play with degenerate orbitals. Read on.
23.3 Linear combinations of degenerate orbitals
313
Symmetry Theory
23.3 Linear combinations of degenerate orbitals 23.3.1 A quick theorem on degenerate orbitals There are infinitely many wave functions in each degenerate level, because linear combinations of degenerate wave functions always produce other wave functions of the same energy. The proof is quick and easy. If Ψ1 and Ψ2 both have energy E, then because H is a linear operator H@a Ψ1 + b Ψ2 D = a H@ Ψ1 D + b H@ Ψ2 D = a E Ψ1 + b E Ψ2 = E Ha Ψ1 + b Ψ2 L
Since a Ψ1 + b Ψ2 plays the role of Ψ in H@ΨD = E Ψ, it must be another eigenfunction with the same energy E. So the three functions shown in each degenerate level of Figure 23.3 are just the winners of a beauty contest; other linear combinations not shown are just as valid, but look sort of lumpy and asymmetric. Their magnificent continuous flow from one to another comes out only when you see them in a movie, as you will below in Subsection 23.3.3.
23.3.2 Orthogonal basis functions In our discussion of the character table, we said that degenerate levels named E are two dimensional; that is, they need two basis functions to span the function space. An orthogonal pair of basis functions can be extracted from any two linearly independent functions. As an illustration, we take ΨE1g A0 °E and ΨE1g A120 °E from Fig.23.3. These functions are a bit unsightly, so their full
algebraic definition is closeted in the preliminaries as Ψ0N and Ψ120N. You can call them forth for inspection if you like. Below, we just plot them to verify that they are what we say :
°
ΨE01 g
°
ΨE120 1g
Fig. 23.4 Two linearly independent benzene orbitals from the E1 g level. These
314
are the input to Orthogonalize, below.
Linear combos
Fig. 23.4 Two linearly independent benzene orbitals from the E1 g level. These are the input to Orthogonalize, below.
These functions will be fed to the Orthogonalize operator, which by default implements the Gram-Schmidt orthogonalization procedure. But when orthogonalizing functions, you must tell it what to use for the scalar product of two functions. There are a number of things that are used in different kinds of problems, but in quantum mechanics the scalar product of functions f and g is always Ù Ù Ù f@x, y, zD* g@x, y, zD â x â y â z, where the integrals run over all space. When both functions are real, this comes down to NumInt@f1_, f2_D := NIntegrate@Hf1L Hf2L, 8z, -¥, ¥<, 8x, -¥, ¥<, 8y, -¥, ¥
Off@NIntegrate::"slwcon", NIntegrate::"eincr"D; 8timeOrth, 8ΨE1g0, ΨE1g90<< = Orthogonalize@8Ψ0N, Ψ120N<, NumIntD ChopAð, 10-8 E & Timing; timeOrth Second 8ΨE1g0, ΨE1g90< 42.5846 Second
:0.917217 ã-3.90747-5.59104 x-2 x
2 -4.84198
y-2 y2 -2 z2
I-1 + ã5.59104 x M Iã2.79552 x + 2 ã4.84198 y +
2 ã2.79552 H2 x+1.73205 yL + ã2.79552 Hx+3.4641 yL M z, 2 -4.84198
1.58867 ã-3.90747-2.79552 x-2 x
I1 + ã5.59104 x M I-1 + ã9.68397 y M z>
y-2 y2 -2 z2
It is more meaningful to look at the contour plots:
°
ΨE01 g
°
ΨE90 1g
°
°
ΨE01 g * ΨE90 1g
Fig. 23.5 Two orthogonal basis functions for the E1 g level, and their product.
It is clear that the first two are orthogonal because their product (third panel) is made of equal but opposite lobes, and so must integrate to 0. If each degenerate space is expressible as linear combinations of a small number “ basis functions” then the most economical display of the space is just the basis functions. The Gram-Schmidt orthogonalization procedure (or the numerical 315 Householder algorithm) provides a quick, practical way of doing this. Here is the result for the benzene orbitals :
Symmetry Theory
If each degenerate space is expressible as linear combinations of a small number “ basis functions” then the most economical display of the space is just the basis functions. The Gram-Schmidt orthogonalization procedure (or the numerical Householder algorithm) provides a quick, practical way of doing this. Here is the result for the benzene orbitals :
Fig. 23.6 Orthonormal benzene orbitals. The degenerate rows are only twofold degenerate, so only two basis functions are needed. The nodal planes of one partner are reflection planes of the other, ensuring orthogonality.
The two orthogonal shapes in each degenerate level differ by more than a simple reorientation. Nevertheless, the “new” shape on the right is just a linear combination of reoriented shapes.
316
Linear combos
23.3.3 Movies of the whole degenerate space In a twofold degenerate level, we can add any two basis functions with coefficients Cos[Α] and Sin[Α] and then let Α run around the circle. This will give us a quick tour of the whole space. With Mathematica in front of us, this is not an impractical idea. A convenient function named E1gPicture[Α] is defined in the preliminaries. Take a look if you are interested. On your own E1gPicture[0] shows the basis state with vertical node; E1gPicture[90] shows the basis state with horizontal node. Do these, and try other mixing angles. Using the function E1gPicture, it is easy now to tour the whole space in a movie. Interactive readers can activate the next cell and see the whole thing : tblE1g = Table@E1gPicture@ΑD, 8Α, 0, 350, 10
For the book, here is every fifth cell of the movie:
Table@E1gPicture@Α, 50D, 8Α, 0, 360, 40
317
Symmetry Theory
The two-node movie of the E2 u function space (below) is a little tricky to grasp intuitively. You may have to watch it for a while to get it. tblE2u = Table@E2uPicture@ΑD, 8Α, 0, 350, 10
Table@E2uPicture@Α, 50D, 8Α, 0, 360, 40
23.3.4 Invariant function spaces in general 318
Linear combos
23.3.4 Invariant function spaces in general The movies you have just seen are examples of a space that is invariant to the transforms of group D6 h . Technically, this means that if you take any inhabitant of the space (any frame of the movie) and subject to any D6 h transform, the result is just another frame of the movie (or perhaps, one that lies between two frames). Now consider this: Given an arbitrary function, does it belong to an invariant space? The answer is always yes, as you will see by the following argument: You can make an invariant function space for any function by simply applying all the symmetry rules of some group to it. If there are h elements in the group, and if rule1 is the identity, Ψ/.{rule1,rule2,… ,ruleh}= {Ψ,Ψ2,… ,Ψh} Now think about applying any one of these symmetry rules again to any one of the generated functions; for instance, Ψ2/.rule3=(Ψ/.rule2)/.rule3 =Ψ/.(rule2/.rule3) But rule2/.rule3 is just rule2Ä3, and 2Ä3 is in the group. So this rule has already been applied to Ψ, and its result is already in the list of transformed functions. So this list spans an invariant space that contains the original arbitrary Ψ2. There, that was easy. Click to an End note to see this actually carried out. There are some interesting issues that arise, and we show how to deal with them.
23.4 Qualitative meaning of degeneracy There is qualitative difference between the physics of the single state of a nondegenerate level, and the infinitely many states of a degenerate level. The electron density cloud in a nondegenerate state has a definite unique natural shape. The shape can be perturbed, but it takes energy to do so, and the cloud returns to its natural shape when the perturbation is removed. A good nondegenerate example would be a ground state He atom bouncing from a solid collision object. Before the collision it is absolutely spherical. We consider only a gentle collision with energy less than the lowest electronic excitation. As the atom comes to rest against the collision object, its former kinetic energy is converted to potential energy stored in a distortion of its spherical shape. But this is not a stationary state, and it immediately begins to recover. To do this, it has to spring away from the collision object. When the electron cloud has recovered its natural shape, the collision energy is fully 319 reconverted to kinetic energy and an “elastic” collision has occurred.
from a solid collision object. Before the collision it is absolutely spherical. We consider only a gentle collision with energy less than the lowest electronic excitation. As the atom comes to rest against the collision object, its former kinetic energy Symmetry Theory is converted to potential energy stored in a distortion of its spherical shape. But this is not a stationary state, and it immediately begins to electron cloud has recovered its natural shape, the collision energy is fully reconverted to kinetic energy and an “elastic” collision has occurred. By contrast, the electron density cloud in a degenerate level has no single definite shape. It can take on a continuous range of shapes without any expense of energy, and therefore without any restoring force whatsoever. Sometimes the range of shapes looks like a reorientation, but in other cases the range includes energy-neutral plastic deformations. (Remember the s-p “hybridization” pictures in your freshman chemistry textbook? This is exactly what they were talking about. In the H atom, the s and p orbitals are exactly degenerate and can mix without energy cost, but with a great change in the density cloud). Because of this, degeneracies allow zero-cost changes in bonding at the saddle point of reactive collision complexes Without such degeneracy, reactive collisions would have to be so energetic that bonds would be fully broken before reforming as new species, and this would rule out many chemical reactions at room temperature. Life would be impossible without degeneracy.
23.5 Accidental degeneracy We make a very bold and simple statement : Symmetry is the cause of degeneracy in quantum mechanics. Throughout this chapter we have seen that geometrical symmetry in the molecule causes algebraic symmetry in the Hamiltonian, and algebraic symmetry in the Hamiltonian causes degeneracy in some of its eigenstates. There are exceptions to this rule, but they all involve non-quantum parameters (like electric or magnetic field, or bond length) that cause two levels to cross at a particular value of the parameters. Exactly at the crossing point, there is an “accidental” degeneracy that seems very surprising in the symmetry you are using to analyze the problem. But you may rest assured that this degeneracy is the consequence of some higher symmetry that you may not yet have recognized. A very simple example of this is offered by the orbitals of cyclopropenylCation, C3H+3 , discussed Chapter 40 (AtomicOrbitalSALCs). If the three C atoms are arrayed as an irregular triangle in the x,y plane (group Ch ), the three Π orbitals of C3H3 all have different energy. But the bond lengths are non-quantum parameters in this calculation, and if they are all set equal, two of the orbitals develop an “ accidental” degeneracy. Of course, the equilateral triangle belongs to a higher symmetry (D3 h ), and the degeneracy of the two orbitals is expected 320 required in D3 h . This has spectroscopic consequences, called the JahnTeller effect.
C3H+3 , discussed Chapter 40 (AtomicOrbitalSALCs). If the three C atoms are arrayed as an irregular triangle in the x,y plane (group Ch ), the three Π orbitals of C3H3 all have different energy. But the bond lengths are non-quantum Accidental in this and if are all set two of the orbitals to a higher symmetry (D3 h ), and the degeneracy of the two orbitals is expected and required in D3 h . This has spectroscopic consequences, called the JahnTeller effect. But the most famous example of pseudo-accidental degeneracy is the “shell” degeneracy of one-electron atoms, which is elementary and very sophisticated at the same time. In shell 2, the 2s orbital is degenerate with any function spanned by {2px, 2py,2pz}. In shell 3, the 3s orbital is degenerate with the three 3p's and with the five 3d's; and so on. Rotational geometry explains why, in any shell, the three p's have the same energy, or why the five d's have the same energy, but it cannot explain why, in shell n, the energies of {{one ns}, {three np's}, {five nd's},… } are all exactly equal. In older quantum books this intra-shell degeneracy was the prime example (indeed, the only example) of non-perturbative “accidental” degeneracy. It is now recognized as a dynamic symmetry, arising from a most unexpected quarter.
23.6 Dynamic symmetry A dynamic symmetry is a a quantity with a formula that depends on constantly changing quantities, but which itself is constant in time. The only familiar example is the angular momentum, given by L = r@tD ´ p@tD. However, with the help of Lie groups and their connection with commuting quantum operators, it was finally recognized that the one-electron atom, by virtue of its pure 1/r potential, possesses an extra dynamic symmetry that accounts for the shell degeneracies. (With two or more electrons, electronelectron repulsion ruins the pure 1/r potential and causes shell degeneracy to break.) This dynamic symmetry occurs also in the classical mechanics of planetary systems, which also obey a 1/r potential. Isolated mechanical systems obey conservation of energy, linear momentum, and angular momentum. But in planetary systems there is another one. It is easy to describe and understand; it was a fact known to Newton, though he did not know its formula or think of it as a constant of the motion. It is called RL, the Runge-Lenz vector. It runs through the center of mass and through the perihelion of each planet's orbit. It is a dynamic symmetry because it is computed by the formula r@tD RL@t_D = p@tD L - m k
Ë r@tD Ë
(23.7)
where p@tD is linear momentum of the planet, L is its angular momentum, and r@tD is the radial position of the planet from the center of mass, m is the 321 reduced mass, and k is from the potential -k/r. Despite the fact that p and r are constantly changing, RL is rock-solid. In this it is like the angular
Symmetry Theory
where p@tD is linear momentum of the planet, L is its angular momentum, and r@tD is the radial position of the planet from the center of mass, m is the reduced mass, and k is from the potential -k/r. Despite the fact that p and r are constantly changing, RL is rock-solid. In this it is like the angular momentum. This fact makes the position of the perihelion direction a constant in the frame of the fixed stars. This is why most planets run over the same orbit, year after year. Well, almost the same orbit. In multi-planet systems every planet feels all the others, so the total potential is not exactly 1/r , and perihelions do wander a bit. But for all our planets, save one, the wandering is mainly accounted for by Jupiter's attraction. The one exception is Mercury. Mercury shows an extra steady precession of its perihelion that was a mystery right down into the 20th century, when it became a great early triumph of special relativity. Mercury moves faster than any other planet as it rounds its aperihelion (nearest distance to the sun). There it is so fast that it picks up a detectable amount of relativistic mass. Alternatively, you could say that it feels a detectable relativistic perturbation of the sun's 1/r potential. Either way, it loses the absolute constancy of its Runge-Lenz vector direction, and its orbit undergoes a constant, observable precession in the frame of the fixed stars. Other dynamic symmetries arise from other potentials that appear on the ultimate microscopic scale of the structure of matter. To mention a few, they are called charm and color, for instance. This dealt with by Lie groups. But this book must stick with simple geometric symmetry.
23.7 Motion reversal symmetry The character tables of several groups have a feature that is due a physical effect that lies outside the mathematics of group theory, but which has affected the way the Mulliken names of symmetry species. H [Ψ[Ξ,Η,Ζ]] Exp[+ä Ω t]= (-ä/Ñ)¶t Ψ[x,y,z, + t]
(23.8)
H [Ψ [x,y,z]] Exp[-ä Ω t]= (+ä/Ñ)¶t Ψ [x,y,z,-t] (23.9) *
*
The space-dependent part of the quantum state (as shown in Figs. 23.3 and 23.6) is not complete. The complete eigenfunction also has an exponential time dependence factor, so that Y[x,y,z,t] = Ψ[x,y,z] Exp[ä Ω t], where the angular frequency Ω is energy / Ñ. In group theory this shows up whenever a group permits 2-D rotation in either clockwise or counterclockwise sense. The mark of such groups is complex-valued characters. 322
The space-dependent part of the quantum state (as shown in Figs. 23.3 and 23.6) is not complete. The complete eigenfunction also has an exponential time
Motion reversal
= whenever a group permits 2-D rotation in either clockwise or counterclockwise sense. The mark of such groups is complex-valued characters. imCh = Select@GroupCatalog, Not@FreeQ@CharacterTable@ðD, ComplexDD &D 8C3, C3h, C4, C4h, C5, C6, C6h, S4, S6, S8, T, Th<
Here is one of the character tables: BoxedCharacterTable@"C6"D C6
1
1
1
1
1
E
C6
A
1
1
1
1
1
1
B
1
-1
1
-1
1
-1 -Ε*
E1a 1 -Ε E1b 1 -Ε*
C62 C63 C64 C65
Ε* Ε
-1 -1
Ε Ε*
¬ Class populations Note : Ε = Exp@- 2 Π ä 3D
1
9H z L, I x2 + y2 M, I z2 M, H Iz L=
-Ε
E2a 1
Ε*
Ε
1
Ε*
Ε
E2b 1
Ε
Ε*
1
Ε
Ε*
Basis functions
9I Hx ±ä yL3 M= 8H x + -ä y L< 8H x + ä y L<
9I x2 - 2 ä x y - y2 M= 9I x2 + 2 ä x y - y2 M=
The E species in these groups are not truly two-dimensional; each has a one-D rep supported by a power of x ± ä y. One relates to clockwise rotation; the other, counterclockwise. But such conjugate one-D species were made into honorary two-D species by Prof. Mulliken, who created the naming scheme. We return a bit toward a strict naming system by appending an a or b to the name. This helps when counting species. A true 2-D species E counts as only one, but Ea and Eb should count as two. This keeps the character table square, for instance.
23.8 End Notes
23.8.1 Orbitals and water waves You can see this in a fountain with six small hexagonally arrayed jets of water, alternately covered and uncovered by waves in the pond. When a jet is covered, its water adds to the local wave amplitude, maintaining the wave. When uncovered, it sprays out over a wide area, doing nothing for the wave shape. Waves of any of the various orbital shapes can develop and be maintained, until the wind provokes a change from one mode to another. A steady wind favors the waves with a single nodal line perpendicular to the wind direction. There is (or used to be) a fountain like this near the old train station in St. Louis.
23.8.2 Orthonormalization
323
Symmetry Theory
23.8.2 Orthonormalization With energies and boundary conditions set appropriately, any one of the panels of Fig. 23.3 can be generated by a numerical solver. However, the solver cannot tell you about the degeneracy of the whole set of solutions. For this, you need three things: one good numerical solution, the Hamiltonian symmetry transforms, and a Gram-Schmidt orthogonalization. Here is the procedure : First, get your numerical integrator to make a function with a simple nodal pattern, such as the left-most function of each degenerate row of Fig. 23.3 . Then transform this function by all the Hamiltonian symmetries, pruning away any duplicates. Finally, feed all the survivors to a Gram-Schmidt orthogonalization procedure, which will return a minimum set of orthonormalized basis functions for the given level. GramSchmidt will use any inner product (or Scalar Product) formula you give it in the option InnerProduct®fn . Mathematicians know of many kinds of scalar products, but the only one used in quantum mechanics is SP1,2 == à JΨ1 @rDN Ψ2 @rD â r *
all space
Orthogonalize uses Gram-Schmidt by default. It is completely automated, but here is a description of how it works. It accepts a list of functions 8Ψ1 , ¼, ΨN <, and without further ado, it normalizes Ψ1 and accepts it as the first basis function Ψ1 B . Then it calculates Ψ2 B = Norm@Ψ2 - Ψ1 SP1,2 D as a possible second basis function. If nonzero, Ψ2 B is accepted and added to the basis list. Functions Ψ1 B and Ψ2 B are necessarily orthogonal because SP1 B,2 B == à JΨ1 @rDN IΨ2 - Ψ1 SP1,2 M â r == *
all space
à JJΨ1 @rDN Ψ2 - JΨ1 @rDN Ψ1 SP1,2 N â r == SP1,2 - SP1,2 = 0 *
*
all space
Then it continues on to Ψ3 , attempting to extract from it another nonzero function Ψ3 B orthogonal to both Ψ1 B and Ψ2 B . If it succeeds, it adds Ψ3 B to the basis list; if not, it passes on to Ψ4 , etc., always hopeful that it may find a new orthogonal function. When it finishes the last function ΨN it returns a List of all the orthonormal basis functions found. Thus may a complete set of numerically exact basis functions be generated, starting from any one numerically exact orbital of the level. GramSchmidt always returns a list of orthonormal functions, but note that the list returned depends on the order of the functions in the list submitted. This is just reality; there are infinitely many ways to specify the basis functions. To a human, some lists look simpler than others, and we tend to focus on the nicelooking ones. But to a computer, all basis lists look the same aesthetically, and 324 there is no way to choose a “best” one.
GramSchmidt always returns a list of orthonormal functions, but noteEnd that the Notes list returned depends on the order of the functions in the list submitted. This is human, some lists look simpler than others, and we tend to focus on the nicelooking ones. But to a computer, all basis lists look the same aesthetically, and there is no way to choose a “best” one.
23.8.3 The simplest example: parity Let P be an operator that changes the sign of the x coordinate. Many Hamiltonians are invariant under this operator. The kinetic energy is always invariant to it, and the potential energy of anything with a Σx reflection plane) is also. For the eigenfunctions Ψ of all such Hamiltonians we can write P@Ψ@xDD = Ψ@-xD = p Ψ@xD
where p is the eigenvalue of P . Note that P2 is the identity operator, because two changes of sign on x get you back to the original. P2 @ΨD = P@ P@ΨDD = P@p ΨD = p P@ΨD = p2 Ψ = Ψ
So p2 = 1, and p = ± 1. So the most that P can do is to change the sign of Ψ. If P[Ψ] = Ψ we say that Ψ has even parity; if P[Ψ] = -Ψ , odd parity. Functions of even and odd parity are easy to spot graphically :
Odd parity
Even parity
Note that the odd parity function will integrate to zero, because whatever is on the right will cancel with an equal but opposite contribution from the left. If you think you need a formal proof of this, read on.
23.8.4 Construct the invariant space of an arbitrary function Click back above for the introductory discussion. Now we do a concrete example. Generating the space is easy, but the cleanup requires a little ingenuity. We take as our example function
325
Symmetry Theory
3 Ix5 y + 2 x3 y3 + x y5 M
F=
; 2
gp = "D3"; First, rescale the function so its first coefficient is 1. (The function scale is defined in the preliminaries.) fn = scale@FD Expand x5 y
x3 y3
+
4
+
2
x y5 4
Make the raw invariant space:
basis1 = fn . SymmetryRules@gpD Expand; % Size@6D
:
x5 y
x3 y3 +
x y5
4 3 x6
4
x5 y -
16
x5 y
16
8 x5 y +
16
16
4
3 x4 y2 + 16
x y5
x y5
16
, 4
, 16
3 y6 -
8
x y5 -
2
3 y6
8
3 x2 y4 +
, 16
x3 y3 -
4
+
16 1
x5 y ,-
16
3 x2 y4 +
4
3 y6
1 +
x3 y3
1 +
8
3 x4 y2 +
3 y6 +
8
8
x3 y3
1 -
16
x y5 3 x2 y4 -
16
3 x2 y4 -
+ 4
1 -
4
x y5
1
3 x4 y2 16
x3 y3 3 x4 y2 -
16
3 x6 + 3 x6
8
1
x3 y3
1 -
16
+ 8
1 -
3 x6 -
,-
2
x5 y
1
+
>
16
Apply scale, and then hit it with Union to get rid of redundancies : basis2 = Map@scale, basis1D Union :x5 y + 2 x3 y3 + x y5 , x6 -
x6 +
2 x5 y
+ x4 y2 -
4 x3 y3
3
3
2 x5 y
4 x3 y3
3
+ x4 y2 +
3
- x2 y4 -
2 x y5
- y6 ,
3 - x2 y4 +
2 x y5
- y6 >
3
That's getting better. If you stare at it for a little while, you will see that the two generated functions are just the original function, plus other stuff. Sometimes this happens; sometimes not. But when it does, use the remove operator, below. It finds the coefficient that removes the first term of f1 from f2, and then removes the whole thing. The If makes sure that f1 is not removed from f1 itself: Clear@removeD; remove@f2_, f1_D := Module@8lead, cf<, If@f1 === f2, Return@f1DD; ; 326
End Notes
lead = f1P1T ; cf = Coefficient@f2, leadD; Hf2 - cf * f1L Expand D; Map remove onto basis2, hit it with a Union, and you have it:
basis3 = Map@remove@ð, fnD &, basis2D Union :x5 y + 2 x3 y3 + x y5 , x6 -
2 x5 y
+ x4 y2 -
3 x6 +
2 x5 y 3
4 x3 y3
- x2 y4 -
3 + x4 y2 +
4 x3 y3 3
2 x y5
- y6 ,
3 - x2 y4 +
2 x y5
- y6 >
3
Pull it all together in one function : Clear@makeInvariantSpaceD; makeInvariantSpace@F_, gp_D := Module@8fn, basis1, basis2, basis3<, fn = scale@Expand@FDD; basis1 = fn . SymmetryRules@gpD Expand; basis2 = Map@scale, basis1D Union; basis3 = Map@remove@ð, fnD &, basis2D Union; Map@scale, basis3D Union D Try it out: invSpace = makeInvariantSpace@F, gpD 9x5 y + 2 x3 y3 + x y5 , x6 + x4 y2 - x2 y4 - y6 =
We must test the reputed invariance from first principles, and see if it really is. Since the functions are polynomials, all we have to do is assure ourselves that the group operations create no new polynomial terms. Here is an operator that evaporates the coefficients from any polynomial, returning just a list of its bare terms : bareTerms@poly_D := Module@8termLst, coeffs<, termLst = Expand@polyD . Plus ® List; coeffs = termLst . 8x ® 1, y ® 1, z ® 1<; termLst coeffsD Use it to make a list of terms in both functions before the big group transform : before = Map@bareTerms, invSpaceD Flatten Union 9x6 , x5 y, x4 y2 , x3 y3 , x2 y4 , x y5 , y6 =
Apply all the symmetry rules of the group, and see if anything new appears: 327
Symmetry Theory
Apply all the symmetry rules of the group, and see if anything new appears: after = Map@bareTerms, invSpace . SymmetryRules@gpD ExpandD Flatten Union 9x6 , x5 y, x4 y2 , x3 y3 , x2 y4 , x y5 , y6 =
before == after True
Indeed, that little two-polynomial space was invariant under D3 .
328
24. Transformation of functions Preliminaries
24.1 What is a function transform ? Consider a functional form f that depends on the list {x,y}, and think of its contour plot over the x,y plane. If you want a concrete example, think of f
x ,y
:
x2 y;
We make its contour plot with BlueContourPlot, defined in the preliminaries. It is just the standard core operator ContourPlot, with a few options to make it look prettier. bcp1 BlueContourPlot f
x, y
, x,
2, 2 , y,
2, 2
2
1
0
1
2 2
1
0
1
2
Fig. 24.1 Contour plot of the function f[{x,y]] = x2 y
Here is our basic question, in concrete form: What function has a contour plot that looks just like this, but rotated 20 degrees counterclockwise? To begin, let's think about how to rotate a single point {x,y} by degrees counterclockwise. The basic formula is quite familiar. If we let Rmat we can define a x ,y
:
Cos Sin
Sin Cos
that will rotate any {x,y} point by +20 degrees: : Rmat 20. Degree . x, y
Try it on a point that lies on the positive x-axis: W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_24, © Springer Science+Business Media, LLC 2009
329
Symmetry Theory
1, 0 0.939693, 0.34202
It moved left and up. Point your right thumb at your nose to verify that this is right handed (or counter-clockwise) rotation, as seen from a point on the positive side of the z axis.
24.2 An intuitive way (but it's wrong) Now we do something that usually seems intuitively correct to innocent people. If we want a contour plot to rotate by +20 degrees, we will just rotate all the points by +20 degrees before we compute the function. We apply to the general {x,y} point before we apply f to it : bcp f
BlueContourPlot x, y , x, 2, 2 , y,
2, 2
2
1
0
1
2 2 x, y Fig. 24.2 Contours of f with • a rotation by +20 °.
1
0
1
0.93 x 0.34 y
2 2
0.34 x
0.94 y ,
It seems to work pretty well. But wait... Do you notice something strange? Positive rotations are counterclockwise, but this plot has rotated clockwise. What causes this? Maybe we need to think a little more carefully.
24.3 The right way We begin with a careful statement of what we want :
330
Right way
We have a transform that transforms the independent variables x,y according to xold , yold xnew , ynew . We define the functional form fnew to be such that fnew xnew , ynew
fold xold , yold
We already know the meanings of fold , xold , yold , xnew , and ynew . Therefore, this is a definition of fnew . In words: The height of the contour of fnew at the point xnew , ynew must be the same as that of fold at the point xold , yold . Thus when the new point rotates counterclockwise, the whole contour will rotate counterclockwise. If we can get rid of xold and yold , rewriting them in terms of xnew and ynew , then our definition of fnew will be in perfectly standard form, with a function of independent variables on the left, and its meaning on the right. So pretending we know the functions xold xnew , ynew and yold xnew , ynew we write fnew
xnew , ynew fold xold
xnew , ynew
, yold
xnew , ynew
How do we construct xold , yold out of xnew , ynew ? We certainly do not use because we have already said xnew , ynew xold , yold 1 We want the opposite of this. Apply the inverse transform to both sides, and you have it: 1 1 xnew , ynew xold , yold
Whatever
does,
1
undoes, so this becomes 1
xnew , ynew
xold , yold
or for linear transforms based on matrix , just use the matrix inverse of {xold , yold } =
1
:
.{x,y}
Now we use this to eliminate xold , yold from the equation for fnew : fnew
x, y
fold
1.
x, y
In our intuitive calculation we used instead of 1 , and got it wrong. Now it is easy to fix it. Define the inverse operator just like the direct operator, but 331 with negative angle. In the preliminaries we made 1 into a symbol. So
Symmetry Theory
In our intuitive calculation we used instead of 1 , and got it wrong. Now it is easy to fix it. Define the inverse operator just like the direct operator, but with negative angle. In the preliminaries we made 1 into a symbol. So 1
x ,y
: Rmat
20. Degree . x, y ;
Just rerun the same ContourPlot, but with inverse operator : BlueContourPlot f
1
x, y
, x,
2, 2 , y,
2, 2
x, y 0.93 x 0.34 y 2 0.34 x 0.94 y , Fig. 24.3 Contours of f with • a rotation by -20 °. Now the plot itself rotates by +20 °.
Cynics will say that the change in the sign of the angle is just a kludge to make it turn the other way. Yes, it does that, but it is also profoundly correct. The inverse formula works even for nonlinear transforms. Really, we have given a pretty good proof of the following theorem : If you want the contour plot of f[{x,y, }] to be transformed by 1 x, y, transform , make a plot of f . The function f
1
x, y,
is just another function of {x,y, }, and
it needs a function name of its own. We will call it [f], and we will write the function and its variables as [f][{x,y, }]. Mathematica supports this kind of function name. It is traditionally written simply as f[{x,y, }]. But this notation should be abandoned because it does not indicate the scope of the . It might mean that should apply to f and x and y as well. No, we mean it to apply only to f. Rewriting in a form we will pick up and use in the next chapter
332
Right way
f
x, y, z
f
1
x, y, z
The left side is what we want to know, and the right side shows how to construct it.
24.4 End Notes 24.4.1 Kludge This is an official English word. The Oxford English Dictionary says: Kludge (klooj) : An ill-assorted collection of poorly-matching parts, forming a distressing whole; esp.in Computing, a machine, system, or program that has been improvised or “bodged” together; a hastily improvised and poorly thought-out solution to a fault or “bug”.
333
25. Matrix representations of groups Preliminaries
25.1 Representation theory We have worked extensively with groups of Cartesian transform matrices that multiply exactly like a corresponding abstract group, and you may have the impression that these are the only matrices that can represent the group. This is far from the truth. The Cartesian representation (technically, “ the representation based on 8x, y, z<”) is only one among an infinite possible number of representations. In this chapter we will develop the concept of matrix representation in its full generality. Click back to the basic definition of symmetry (Chapter 4) and read it again. There are many kinds of symmetric objects in chemistry and physics, each with its own kind of transformation rule. In the Representation Theorem below, we use such general language that we manage to deal with all of them at once. This is wonderful, but unless you already know some examples, it leaves you with an empty feeling. So we follow the general theorem with three kinds of examples, which should restore you.
25.2 Definition of representation
Definition of representation Let the matrices {A,B,… ,Z} correspond to the elements {A,B,… ,Z} of an abstract group. The matrices are a representation of the group if for every relation A Ä B = C in the abstract group it is true that A . B = C in the corresponding matrices. In words, the matrices {A,B,… ,Z} represent the group in the sense that every relation in the group multiplication table is also true for Dot products of the matrices.
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_25, © Springer Science+Business Media, LLC 2009
335
Symmetry Theory
25.3 Faithful and unfaithful reps Note that the implication in the definition runs only one way. If a product relation holds in the abstract group, then it must also hold in the representation. Sometimes the converse of this is true and sometimes not. Explicitly, the converse is : If a product relation is true among the matrices, then it is also true among the group elements. When the converse holds, the representation is called a faithful representation. When not, unfaithful. You have already seen many examples of faithful representations. (All the matrix groups tabulated under the names CartRep["group"] are faithful.) So you need to see immediately an example of an unfaithful representation, which is a new idea. We define two small groups : grpA = CartRep@"C4"D; grpB = :K
1 0 -1 0 1 0 -1 0 O, K O, K O, K O>; 0 1 0 -1 0 1 0 -1
First, we check for closure: MultiplicationTable@Dot, grpAD
881, 2, 3, 4<, 82, 3, 4, 1<, 83, 4, 1, 2<, 84, 1, 2, 3<<
MultiplicationTable@Dot, grpBD
881, 2, 1, 2<, 82, 1, 2, 1<, 81, 2, 1, 2<, 82, 1, 2, 1<<
Neither table contains any question marks, so they both close. We accept this as evidence that they are both groups. So grpA is the point group C4 , the rotations by multiples of 90°, with elements
9E, C4 , C24 , C34 =. In grpB you will note immediately that this matrix list includes repeats. However you will recall that this is not illegal. We make a truth table for multiplication, taking all possible cases of indices {i,j,k} in both groups,, and bracketing together the results for grpA and grpB. TFtable = Table@8 grpAPiT.grpAPjT == grpAPkT, grpBPiT.grpBPjT == grpBPkT<, 8i, 4<, 8j, 4<, 8k, 4
Yes, both groups have 4 members, and 43 is 64. So we have exhaustive examination. We Select all the cases where grpA yields a True: 336
Faithful and unfaithful reps
Yes, both groups have 4 members, and 43 is 64. So we have exhaustive examination. We Select all the cases where grpA yields a True: Select@TFtable, HðP1T === TrueL &D Union 88True, True<<
In every case where grpA yields a True, then grpB does also. This means that grpB represents grpA. But is it a faithful or an unfaithful representation ? If it is faithful, then a False in grpA will imply a False in grpB, and there will be no pairs {False,True}. Look for them : Select@TFtable, Hð === 8False, True
No! There are plenty of them, so grpB is an unfaithful representation of grpA. We mentioned this before in Chapter 14 (CharacterTableIntro). All groups have a representation that is the ultimate in unfaithfulness : Let each group element be represented by a simple 1. The test is: “ If A Ä B C, then it must be true that 1 ´ 1 = 1”. Indeed, this is a true syllogism (however scanty the content). So a list 1's is indeed a representation, called the trivial representation, or the totally symmetric representation (because 1 is unchanged (or symmetric) under every transform of the group). Why do mathematicians make such a seemingly silly definition? It's because we will be interested in counting the different irreducible representations of groups, and the theorems will be prettier if we count the trivial representation as a true representation.
25.4 MorphTest In order to test the constructions that we make below, we have written an operator called MorphTest that tests any list of matrices to see if it is a representation of a given group; and if so, whether it is faithful or unfaithful. It is a straightforward generalization of the test we made above. The thumbnail sketch is MorphTest[slot1,slot2,opts] returns three possible statements: 1) slot1 and slot2 are isomorphic (faithful to each other), 2) slot1 is an unfaithful representation of slot2 3 ) slot2 is an unfaithful representations of slot1 slot1 must be a list of group elements slot2 is either another list of elements or a group name. The opts are Numeric ® False//True and TypeSize ® 0 // nbr. The defaults are False and 0. TypeSize®6 (for example) returns both multiplication tables for homomorphic groups in type size 6; the default TypeSize ® 0 suppresses this. Numeric ® True is used when symbolic identification fails.
337
MorphTest[slot1,slot2,opts] returns three possible statements: 1) slot1 and slot2 are isomorphic (faithful to each other), 2) slot1 is an unfaithful representation of slot2 3 ) slot2 is an unfaithful representations of slot1 Symmetry slot1 Theory must be a list of group elements
The defaults are False and 0. TypeSize®6 (for example) returns both multiplication tables for homomorphic groups in type size 6; the default TypeSize ® 0 suppresses this. Numeric ® True is used when symbolic identification fails.
Try it out on the unfaithful representation of group C4 given above : MorphTest@grpB, "C4"D
slotð1 represents slotð2 unfaithfully HhomomorphismL
For further detail, read the text of the operator in the Symmetry` package.
25.5 Why representations are important The idea of representation begins to assume its true importance when you learn that any collection of symmetric objects can be used to construct a representation. In fact, many physical applications of group theory follow a pattern that goes like this: (1) Identify a set of objects that transform linearly among themselves under the action of a group G of transforms (i.e., identify some objects that span an invariant space). These could be polynomials, infinitesimal rotation matrices, atom orbitals in a symmetric molecule, symmetry adapted combinations of atomic orbitals, molecular orbitals, quantum formulas for spectroscopic operators, or many other things. (2) Use these objects to make a representation of group G . (3) Analyze the representation in a way that will be described. This analysis tells you everything that can be said about the symmetry of the objects. Step 1 is the hard one. Human intelligence is required to identify a suitable group of objects. But once this is done, Step 2 is just calculational work, and can often be automated, as we show in Chapter 27. Step 3, the analysis of the representation, will be described in Chapter 28 (Reducible Reps), then carried out by an amazing method that involves an arbitrary matrix in Chapter 30 (Schur's Reduction), and finally made fast and automatic in Chapter 35 (RepAnalysis).
338
The rep construction recipe
25.6 The rep construction recipe 25.6.1 Rep construction in general We can describe the construction process without specifying what the objects are, or what the transforms are. This is important, because it is the same for all embodiments. Here is the notation we will use: Notation {A,B,… ,Z} are linear transform operators that constitute group G. They "know" how to work on objects 8f1 , ¼, fN <. The operators “belong” to a group G if composition of the operators obeys the multiplication table for G. In detail, if A Ä B = C, then A@B@fi DD = C@fi D. The invariance requirement The space spanned by 8f1 , ¼, fN < must be invariant under each of the transforms {A,B,… ,Z}. A space is invariant under a transform T if the transformed bases, 8T@f1 D, ¼, T@fN D<, are just linear combinations the original bases 8f1 , ¼, fN <, and vice-versa. Remember, symmetric means that something is unchanged under a transform. Here, the individual f objects change, but the space they span does not. So an invariant space is a symmetric space (with respect to a transform T). In plain English, operator T moves points around in the space, but it brings no new points in, and casts no old ones out.
Sometimes 8T@f1 D, ¼, T@fN D< is just a permutation of 8f1 , ¼, fN <. This is invariance, since permutations are just a special kind of linear combination (having only 0 and 1 as coefficients). With these understandings we can state the general representation recipe. It is really just a statement of the invariance requirement, viewed from a new perspective :
339
Symmetry Theory
For every operator TL , find its representation matrix THLL by solving TL @fD = f.THLL
or in index notation
T L @fk D = Ú fh THLL h,k nf
(25.1)
h=1
where the f objects lie in a space invariant under all the transforms T L , and nf is the number of f objects (i.e., the dimension of vector space f). Note that matrix T will be of size nf ´ nf. It may seem odd to you that T multiplies leftward into the vector of f objects. Usually our matrices multiply rightward into vectors. But this is not a mistake; we really do mean leftward multiplication. You will see exactly why when you follow a detailed construction, below.
25.6.2 Check that the recipe works We do a Mathematica-assisted constructive proof for the case of 2 completely general basis objects. That is, we will do the constructions required by Eq. 25.1, and test whether it produces a representation, or not. Then we will argue that the case of N basis objects is essentially the same. Take the invariant linear transforms to be
Arule = 8f1 ® a f1 + b f2 , f2 ® c f1 + d f2 <; Brule = 8f1 ® r f1 + s f2 , f2 ® t f1 + u f2 <;
No 2-D transform can be more general than this. operators that impose these rules :
We need Mathematica
Clear@A, BD; A@u_D := u . Arule; B@u_D := u . Brule; For example:
A@2 f1 + 3 f2 D Collect@ð, 8f1 , f2
Operator A has moved the point, but it is still in the 8f1 , f2 < space. To get the matrices, Eq. 25.1 says that we must solve for the matrix objects in A@8f1 , f2
Operator A has moved the point, but it is still in the 8f1 , f2 < the matrices, Eq. 25.1 says that we must solve for the matrix objects in A@8f1 , f2
The rep construction recipe
A = MatrixOfCoefficients@ A@8f1 , f2
a c r t O, K O> s u b d
And so forth, with all the other elements of the group. Remember, the key property that we want is composition. In other words, we want the compound transform A B (first B , then A ) to be represented by the matrix product A.B . To make sure that this is true, apply the substitution operators, working rightward : form1 = A@B@8f1 , f2
8a f1 r + b f2 r + c f1 s + d f2 s, a f1 t + b f2 t + c f1 u + d f2 u<
Then apply the compounded matrix A.B, working leftward : form2 = 8f1 , f2 <.HA.BL Expand
8a f1 r + b f2 r + c f1 s + d f2 s, a f1 t + b f2 t + c f1 u + d f2 u<
Are they the same? Don't trust your eyes. You are too excited; you have too much invested in the outcome, and you might make a mistake. Let the machine do it: form1 == form2 True
Success ! Yes, A @B@8f1 , f2 , ¼
Symmetry Theory
operators belong to group G, so if the abstract group elements obey A Ä B = C then the operators obey A@B@DD = C@D. Therefore C@8f1 , f2
(25.2)
But Eq. 25.1 says that a matrix C must stand in the position occupied by A .B , so it must be that If A Ä B = C ,
then A.B = C
(25.3)
which was to be proved. Looking back, we used nothing that was unique to the case of 2 basis objects, and it seems clear that the same construction will work for the case of N objects, with any N you like. On your own Using MultiplicationTable["group”], find a non-Abelian table and select a pair of elements where multiplication order makes a difference. Then use CartRep[“element”,“group”] to pull out the representation matrices, and verify that if the table says A Ä B=C , then A.B = C . In Chapter 27 (MakeReps), we will carry out the rep construction for several kinds of basis objects, and automate the constructions.
342
26. Similar representations Preliminaries
26.1 Given two reps, are they similar? A new understanding of congruent will help us below:
We will call two groups of matrices congruent if they have the same group order and the same matrix size.
In the MatrixReview it is shown that if a group A is similarity transformed into a congruent group B, then they both obey the same multiplication table (click to review the theorem). Now think about the converse of this: If two congruent groups of matrices, A and B, obey the same table, then they are similarity transforms of each other. As always, converses are not automatically true. In fact, this one is quite false. The proof is simple: If A is faithful and B is unfaithful, they both obey the abstract group multiplication table. But B must contain an illicit relationship (the essence of unfaithfulness) that is untrue in A , and that relation is maintained in any similarity transform of B. Since A does not have it, it cannot be a similarity transform of B. But there is a little stronger question that remains unanswered. If A and B are faithful representations of some group, is there always a similarity transform that will change one into the other? The formal statement is
Let A and B be different faithful representations of some abstract group. This implies that their elements are in one-to one correspondence Ai to Bi , for all i. Then does there exist a matrix P such that for every member Ai of A and its corresponding member Bi of B, it is true that
(26.1)
Ai = P . Bi . P -1
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_26, © Springer Science+Business Media, LLC 2009
343
Symmetry Theory
This question will launch us into a surprisingly rich development that will occupy the next several chapters, and give us the crowning achievement of finite group theory, the Great Orthogonality. Many applied group theory books skip over the development of the Great Orthogonality and present it as fait accompli. They do this because one cannot conduct numerical experiments in a paper paged book, so they cannot easily show how the ideas developed and led logically to the theorem. But in doing so they skip a development that is one of the most beautiful and surprising in all of mathematics. Our guided tour in the coming chapters will avoid many bypaths and pitfalls, and will include several firm pushes in the right direction. We hope to show that the Great Orthogonality was the result of human curiosity and logic, piqued by some surprising mathematical experiments.
26.2 Universal pseudocommuter matrices 26.2.1 Strengthen the problem We begin our work with a slightly altered form of Eq. 26.1 . Multiplying from the right by matrix P , it becomes Ai .P = P . Bi
(26.2)
Matrix P needs a name. We will call it a universal pseudocommuter matrix for A and B. The "universal" part just means that it is a pseudocommuter for all the elements of the group. The "pseudo" part means that its defining property is similar to commutation, but just a little different. If Bi and Ai in Eq. 26.2 were the same, then P would be a true commuter. We will be very interested in the true commuter equation, but that comes later. Eq. 26.2 is a little stronger than 26.1 because there is no presupposition that P has an inverse, and we can work with the trivial solution P = 0, which plays an important role. Therefore our basic question becomes : When is there a nontrivial solution for P, and can we compute it from the given A and B ? In Eq. 26.2 both sides are linear in P , so any multiple of a solution P is also a solution. Thus P is somewhat like an eigenvector (Any multiple of an eigenvector is still an eigenvector. In fact, if we required Bi to be diagonal, Eq. 26.2 would be the eigensystem equation... but we don't.) Because the group axioms insure that A-1 i always exists, we lose no generality in rewriting Eq. 26.2 as 344
Pseudocommuters
Because the group axioms insure that A-1 i always exists, we lose no generality in rewriting Eq. 26.2 as P = A-1 i .P . Bi
(26.3)
If some matrix P solves this equation for every element i of the two reps, then we still have a valid equation if we sum over the whole group. If the group contains h elements, this gives h P = Ú A-1 i .P . Bi h
(26.4)
i=1
This is a very promising equation because it contains a lot of information from both groups. So all we need is to solve for P. But how?
26.2.2 A bright idea: successive approximations Eq. 26.4, if divided on both sides by h, is of the form P = f[P] , and with this form you can sometimes get a solution for the unknown P by the method of successive approximations. Let P1 be a first guess for the target matrix P. It need not be very good. Then the first improvement is P2 = I 1h M Ú A-1 i .P1 . Bi h
(26.5)
i=1
With P2 in hand we continue to iterate, so that after n rounds we have Pn+1 = I 1h M Ú A-1 i .Pn . Bi h
(26.6)
i=1
Sometimes the successive approximations P1 , P2 , P3 , ..., Pn , Pn+1 oscillate wildly, giving nothing useful; but other times they settle in toward a target matrix P, and when they do you have found a solution to the problem.
345
Symmetry Theory
26.2.3 A much brighter idea However, before implementing this rather wildcat scheme, we scout around a little. How can we use the fact that our matrices form a group? We remember that any sum over the whole group lets one use the rearrangement theorem. Choosing corresponding elements k from both groups, this theorem lets us rewrite Eq. 26.5 as -1 P2 = I 1h M Ú IAi .A-1 k M .P1 .I Bi .Bk M h
-1
(26.7)
i=1
This multiplication reorders both groups in the same way, and since we sum over all the elements, the sum is the same. The first factor in the sum is IAi .A-1 k M
-1
-1 -1 = IA-1 k M .Ai = Ak .Ai -1
(26.8)
so making this substitution, and moving the sum as far inward as possible, -1 P2 = Ak .I 1h Úi A-1 i .P1 . Bi M .Bk
(26.9)
But the parenthesis is just the right side of the original Eq. 26.5 , so P2 = Ak .P2 .B-1 k
(26.10)
P2 .Bk = Ak .P2
(26.11)
or
where k can be chosen as any index in the group. This is an astonishing result. It is exactly the pseudo commuter definition, Eq. 26.2, but with sides switched. It says there is no need for iteration because P2 , as calculated by Eq. 26.5, is already the universal pseudocommuter! Furthermore, P1 was completely arbitrary, so it might as well absorb the factor of 1/h and be called Q.
346
Pseudocommuters
A universal pseudocommuter P for groups A and B is P = Ú A-1 i .Q . Bi h
(26.12)
i=1
where Q is any matrix that makes the formula evaluatable.
When A and B are the same size, nothing prevents the simplest choice of Q, a unit matrix. Then the formula becomes P = Ú h
(26.13) A-1 i .
Bi (if A and B are the same size)
i=1
We anticipated that the formula for P would have an arbitrary multiplicative constant in it. But the general formula contains a whole arbitrary multiplicative matrix. Can this possibly be correct? We must try a numerical example immediately.
26.2.4 A nice square example Here we will make two very different-looking reps of the same size that are actually similarity transforms of each other. Then we use them to construct their universal pseudocommuter, and then carry out the similarity transform from one to another, just to verify it. Group T (all rotations of the tetrahedron) has a very pretty Cartesian representation, so let's use that as our group. In the list of operations below we call up a group G and transform G into A using an arbitrary tangling matrix TA : G = CartRep@"T"D; len = Length@GD; TA = 886, -10, -5<, 87, -5, -3<, 89, 9, 3<<; A = Similarity@G, TA D; MorphTest@A, "T"D
347
Symmetry Theory
Faithful, or Isomorphic Do it again, using a different tangling matrix, and calling the result B : TB = 88-9, -2, 10<, 84, -1, 10<, 8-2, -3, -10<<; B = Similarity@G, TB D; MorphTest@B, "T"D
Faithful, or Isomorphic We will need the inverses of all the B matrices : B-1 = Map@Inverse, BD; Now make the universal pseudocommuter PAB for A and B , using an arbitrarily chosen matrix Q1 : Q1 = 888, -9, 8<, 81, 1, -2<, 83, 0, -4<<; Make the pseudocommuter : PA Q B = â TableAB-1 PiT.Q1 .APiT E len
i=1
::
>, 540 1 318 429 : ,, >, 45 180 540 48 272 1 288 259 1 083 103 :, ,>> 9 180 540 268 513 45 295 666
,-
159 901
1 173 613
, 20 1 571 857
This ought to transform A into B. Will it really do it ? Similarity@A, PA Q BD == B True
348
Pseudocommuters
However unlikely this may seem, it works.
On your own Go back and try this with different Q matrices. In particular, try the unit matrix.
26.2.5 A strange rectangular example By using the word “congruent” we encouraged you to think that reps A and B are of the same dimension. But go back and read Section 26.2 again, this time thinking that reps A and B are of different dimensions. It still makes sense if the pseudocommuter P is rectangular, with the height of A and the width of B : Ai . P = P . Bi . = .K O
or
(26.14)
=
Nothing in the development prevents the usual conclusion, though now Q must be rectangular : P
or
= Úi = Úi
A-1 i
=Úi
.
Q
.
Bi
. .K O i i
(26.15)
i
This is even harder to believe than the original. To test it, make two reps; one 3´3, the other 2´2 :
349
Symmetry Theory
A33 = CartRep@"C3h"D; % GridList Size@5D
:
1
0
0
0 0
1 0
0 1
1
3
-
2
, 3
0 1 0
0 0 -1
1
3
2
2
0
, -
2 0
1 0 0
-
0
2
1
1
, 3
-
0
2 0
1
3
-
2
,
1
0
2 0
-
0
2
-
2 0
1
1
3
2
2
0
>
, 3
-
2 0
1
-
0
2 0
3
-
2 0
-1
1
0
2 0
-1
Make a complex 2´2 representation of C3 h : B22 = MakeRepPoly@8Hx + ä yL, Hx - ä yL<, "C3h"D ComplexExpand; % GridList Size@5D
:
1 0
0 1
1
-
ä
2
,
3
1
+
ä
2
0 1
,
1
-
ä
2
0 , -
+
-
ä
1
-
ä
2
,
2
3 2
0
0 1
ä
2
3
-
+
3
2 0
1 2
, -
0
1 0
-
0 2
1
+
ä
2
3
>
0 2
3 0 2
3 2
-
1
-
2
ä
3 2
Just check it : MorphTest@B22 , "C3h"D slotð1 represents slotð2 unfaithfully HhomomorphismL
Make the rectangular pseudocommuter (Eq. 26.12) using Q32 : A-1 33 = Map@Inverse, A33 D;
Q32 = 8810, -8<, 84, 10<, 88, 9<<; P32 = â IA-1 33 PiT.Q32 .B22 PiTM ExpandAll; 6
% GridForm Size@8D i=1
350
Pseudocommuters
30 - 12 ä 12 + 30 ä 0
-24 + 30 ä 30 + 24 ä 0
Test it on all the elements of the group : Test@i_D := HExpand@A33 PiT.P32 D == Expand@P32 .B22 PiTDL; Table@Test@iD, 8i, 6
Well, perhaps you still don't have to believe it (this is only an example), but at least you must take it seriously. That algorithm for the universal pseudocommuter is a very hardy algorithm.
On your own Further examples won't prove anything, but by working them out you insure that you really understand the process. So do a few other examples.
26.3 Universal true commuter matrices Nothing in Section 26.2 (Universal pseudocommuter matrices) excludes the case where reps A and B are the same. Go back and read through it again thinking A and B are the same. It all still works. Therefore, without any further work, we can say A universal commuter C for rep A is given by C = Ú A-1 i .Q . Ai h
i=1
(26.16)
where Q is any matrix that makes the formula evaluatable. (But if Q is a unit matrix the result is trivial.)
If Q is the unit matrix, the summands are all unit matrices, and C comes out as a constant matrix (h times the unit matrix). Constant matrices commute with all matrices, so this is a correct but trivial result, and it does not lead to the place we want to go. This will be discussed further in Chapter 30 (SchursReduction) where we make great use of the universal commuter.
351
Symmetry Theory
On your own Make a numerical test of universal commuter construction (Eq. 26.16). Then pick an example group and confirm that the answer really is a universal commuter. Does Eq. 26.16 work for lists of matrices that are not a group? Click here for a relevant End note.
26.4 A whiff of Schur's Second Lemma Let's try to crash the computer by asking it to do something impossible. Let's ask it to find the similarity transform matrix for a pair of reps that are not related by a similarity transform. No two different irreducible reps of a group can be similarity transformed into each other, because similarity transforms preserve the characters of the rep, and different irreducible reps have different characters. BoxedCharacterTable@"D6h", 6D D6h 1
2
2
1
3
E C6 C3 C2 C¢ 2 A1g 1 1 1 1 1
3
1
2
C¢¢ inv S3 2 1 1 1
2
1
3
¬ Class populations
S6
Σh Σd
Σv
1
1
1
1
9I x2 + y2 M, I z2 M=
1
-1
3
-1 -1 9I -3 x5 y + 10 x3 y3 - 3 x y5 M, H Iz L=
1
1
-1
-1
1
1
1
1
B1g 1 -1
1
-1
1
-1
1
-1
1
-1
B2g 1 -1
1
-1 -1
1
1
-1
1
-1 -1
0
0
2
1
0
0
2
A2g 1
E1g 2
1
1
-1 -2
-1 -2
1
0
0
0
0
E2g 2 -1 -1
2
A1u 1
1
1
1
1
1
-1
-1 -1 -1 -1 -1
A2u 1
1
1
1
-1
-1
-1
-1 -1 -1
1
B1u 1 -1
1
-1
1
-1
-1
1
-1
1
-1
1
B2u 1 -1
1
-1 -1
1
-1
1
-1
1
1
-1
0
0
-2
-1
1
2
0
0
0
0
-2
1
1
-2
0
0
E1u 2
1
-1 -2
E2u 2 -1 -1
352
2
-1 -1
2
Basis functions
1
9I x3 z - 3 x y2 z M=
9I -3 x2 y z + y3 z M= xz Ix : , > yz Iy :
x2
-
2 xy
y2 2
>
9I -3 x5 y z + 10 x3 y3 z - 3 x y5 z M= 8H z L< 9I 3 x2 y - y3 M=
9I -x3 + 3 x y2 M= x : > y :
x2 z 2 xyz
-
y2 z 2
>
Schur's lemmas
Reps E2 g and E1 u of group D6 h are both 2-dimensional and have simple basis functions that can be read from the character table. So let's construct concrete AE2g and AE1u matrices, and see what happens when we ask it to compute the non-existent pseudocommuter. We construct the universal pseudocommuter all in one cell below, but interactive readers can take it apart and watch it work step by step. AE1u = MakeRepPoly@8x, y<, "D6h"D; BE2u = MakeRepPolyB:
x2 - y2
A-1 E1u = Map@Inverse, AE1u D;
, x y>, "D6h"F;
2
Q22 = 889, -6<, 81, -2<<;
PE1u,E2u == â IA-1 E1u PiT.Q22 .BE2u PiTM Simplify 24
i=1
PE1u,E2u 880, 0<, 80, 0<<
Well, at least the computer did not crash. And indeed, Eq. 26.2 is obeyed with all-zeroes in PE1u,E2u , though every element produces only 0 == 0. As we said before, this is a very hardy algorithm. When asked for the impossible, it produces something that is at least formally correct. This numerical surprise is the clue that leads to Schur's famous Second Lemma.
On your own There are many congruencies among the CartReps of various point groups. Do all groups of matrices that are congruent but non-similar return an all-zero pseudocommuter ? After your own experiments, try to state what you think Schur's Second Lemma will be. Then click here.
353
Symmetry Theory
26.5 End notes 26.5.1 Congruent, non-similar reps Here is a table from which you can pick CartRep congruencies i.e. congruencies among the Cartesian representations. All CartRep matrices are 3´3, so just pick groups with the same group order : Map@8ð, GroupOrder@ðD< &, GroupCatalogD 88C1, 1<, 8C2, 2<, 8C2h, 4<, 8C2v, 4<, 8C3, 3<, 8C3h, 6<, 8C3v, 6<, 8C4, 4<, 8C4h, 8<, 8C4v, 8<, 8C5, 5<, 8C6, 6<, 8C6h, 12<, 8C6v, 12<, 8Ch, 2<, 8Ci, 2<, 8D2, 4<, 8D2d, 8<, 8D2h, 8<, 8D3, 6<, 8D3d, 12<, 8D3h, 12<, 8D4, 8<, 8D4d, 16<, 8D4h, 16<, 8D5, 10<, 8D5d, 20<, 8D5h, 20<, 8D6, 12<, 8D6d, 24<, 8D6h, 24<, 8I, 60<, 8O, 24<, 8Oh, 48<, 8S4, 4<, 8S6, 6<, 8S8, 8<, 8T, 12<, 8Td, 24<, 8Th, 24<<
Groups C2 h and C2 v are congruent; try them. A = CartRep@"C2h"D; Map@Spur, AD 83, -1, -3, 1<
B = CartRep@"C2v"D; Map@Spur, BD 83, -1, 1, 1<
Reps A and B have different character vectors, so they cannot be similar. Will they give an all-zero pseudocommuter? A-1 = Map@Inverse, AD ChopInteger; Q = RandomMat@Dimensions@ADP2TD; P = ApplyAPlus,
TableAA-1 PiT.Q.BPiT, 8i, Length@AD<EE Chop;
% MatrixForm
354
End Notes
0 -20 0 0 12 0 0 0 0
It is not all-zero, but does it obey Ai .P = P . Bi ? Map@ð.P &, AD == Map@P.ð &, BD True
Wow! Originally, we found P to be a pseudo-commuter when A and B were different irreducible representations of the same group. But here, the groups are different, and P is not all zeroes, but the pseudocommuter property still holds ! But before you get too excited, go back and try C4 h and C4 v . Perhaps after muddying the waters for you, we should reclarify them: the allzero P is guaranteed only if the congruent reps are different irreducible representations of the same group.
355
27. The MakeRep operators Preliminaries
27.1 Four MakeRep operators Chapter 25 (Representations) gave the general formula for constructing representations, and a proof that it works in principle. The actual work of constructing various kinds of representations was left for this chapter. You will learn in Chapter 37 (ProjectionOperators) that some of the greatest and neatest applications of group theory involve the use of projection operators. But some projections require a concrete representation belonging to the given species. This is a huge barrier to hand calculation, because whole representations are not tabulated anywhere, and no one (except, maybe, great geniuses and idiots savante) can construct them quickly and accurately out of their head. But the MakeRep operators developed in this chapter deliver them to the common man in a single stroke. In Chapter 25 we said that representation matrices are found by solving for THRL in an equation that expresses the invariance of objects f under transforms TR of group G : The master representation equation T R @fk D =
HRL Ú fh Th,k
N@fD
for k
= {1,…,N[f]}
h=1
where the given quantities are T R is the transform for element R fh is basis object number h N@fD is the number of basis objects
(27.1)
and the unknown to be found is HRL ), the desired rep matrix for element R THRL h,k (or T The solution method depends on the nature of the f objects and their transforms. There is no neat little algorithm that takes care of all cases. In Section 27.2 we present an algorithm MakeRepPoly that works when the f objects are polynomials in {x,y,z}. This chapter is too long to print it all. The next three Sections differ from Section 27.2 (MakeRepPoly) only in the waywith theMathematica, master equation is solved. W.M. McClain, Symmetry Theory in Molecular Physics 357 You10.1007/b13137_27, can come back to ©them on CD when you need them. DOI Springer Science+Business Media, LLC 2009
Symmetry Theory
This chapter is too long to print it all. The next three Sections differ from Section 27.2 (MakeRepPoly) only in the way the master equation is solved. You can come back to them on CD when you need them. In Section 27.3 (closed; please read from the CD) we present MakeRepRot that works when the f objects are infinitesimal rotation matrices 8Ix, Iy, Iz<. In Section 27.4 (closed; please read from the CD) we present MakeRep Atomic. Chemists often need to make representations on the basis of the way atoms or atomic orbitals are swapped around in a molecule by symmetry transforms, and this operator makes a matrix representation on the basis of such swapping. In Section 27.5 we present MakeRepMolec (closed; please read from the CD). This is used when the basis set consists of molecular orbitals; i.e., linear combinations of atomic orbitals.
27.2 Polynomial basis (polynomials in x, y, z) 27.2.1 The tabulated basis functions In Chapter 14 (CharacterTableIntro) we discussed the broad right column of the character table in some detail. Now we will start work with the polynomial bases listed there, so click back if you need to review.
27.2.2 A single polynomial (in one step) When the basis object is a single polynomial p[x,y,z], the “matrix” THRL is of size 1´1; just a number, THRL . Then the master equation 27.1 becomes TR @p@x, y, zDD = p@x, y, zD * THRL
(27.2)
where the transform TR is performed by replacement rules working on x, y, z. Solving is trivial : THRL =
p@x,y,zD.SymmetryRulesInverse@RD p@x,y,zD
Are you surprised that we use the SymmetryRulesInverse rather than SymmetryRules ? If so, click back to the definition of functional transform.
358
List
BoxedCharacterTable@"O"D O
1
8
3
6
6
¬ Class populations
E C3 C42 C4 C2 A1 1
1
1
A2 1
1
1
E
2 -1
2
1
-1 -1 0
0
T1 3
0
-1
1
-1
T2 3
0
-1
-1
1
9I x2 + y2 + z2 M= 8H x y z L<
Basis functions
1 :
-x2 - y2 + 2 z2 3 x2 x : y , z
3 y2
>
Ix Iy > Iz
xy : yz > xz
In the A2 row of the O character table, the only basis object given is the polynomial x * y * z. Further, the Listable property of the replacement operator lets us do all the rules at once: repA2ofO =
x * y * z . SymmetryRulesInverse@"O"D x*y*z
81, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1<
As you see, each number THRL is just a 1 or a -1. Is this a representation of group O? Try MorphTest on it: MorphTest@repA2ofO, "O"D
slotð1 represents slotð2 unfaithfully HhomomorphismL
Yes, it is a representation, but since it consists of only two different numbers, it has to be unfaithful. Make sure that the package operator MakeRepPoly also produces this result : HMakeRepPoly@8x y z<, "O"D FlattenL == repA2ofO True
27.2.3 A list of polynomials (step by step) Raw materials When the basis is a list of polynomials, the master equation 27.1 becomes
359
Symmetry Theory
8p1 , ¼, pN < . SymmetryRulesInverse@RD = 8p1 , ¼, pN <.R G
(27.3)
Now R G is a matrix, and we need an algorithm that solves for it. As usual in algorithm development, we first do an example, step-by-step. We do species E5 of group D6 d . TabulatedBases@"D6d"DP9T 9E5, 98x z, y z<,
9x5 - 10 x3 y2 + 5 x y4 , 5 x4 y - 10 x2 y3 + y5 =, 8Ix, Iy<==
Three basis pairs are tabulated; we take the second : group = "D6d"; basis = 9x5 - 10 x3 y2 + 5 x y4 , 5 x4 y - 10 x2 y3 + y5 =; Transform the basis functions The next step is to transform the basis by applying to them the inverse symmetry rules for every element of the group. Below, interactive readers can remove the semicolon and see them all: allBasisTfs = basis . SymmetryRulesInverse@groupD ExpandAll; Dimensions@%D 824, 2<
The group has 24 members, so we got one transformed basis pair for every element. To keep things simple, we will do the rep matrix for only one group element. Picking element #2, its transformed basis pair, which goes on the left side of the master equation Eq. 26.3, is rule2 = SymmetryRulesInverse@groupDP2T; left = basis . rule2 ExpandAll :-
1
3 x5 +
2 x5 2
5 x4 y
+5
3 x3 y2 - 5 x2 y3 -
2 -
5
3 x4 y + 5 x3 y2 + 5
2
5
3 x y4 +
y5
2 3 x2 y3 -
5 x y4 2
, 2
-
3 y5 2
>
Now make the right side. Use an Array of a[i,j] as the symbolic matrix to be found. We will need the a[i,j] both as a matrix and as a list : dim = Length@basisD 360
List
2
aMat = Array@a, 8dim, dim
8a@1, 1D, a@1, 2D, a@2, 1D, a@2, 2D<
Carefully making aMat operate leftward, the right side is right = basis.aMat
9Ix5 - 10 x3 y2 + 5 x y4 M a@1, 1D + I5 x4 y - 10 x2 y3 + y5 M a@2, 1D,
Ix5 - 10 x3 y2 + 5 x y4 M a@1, 2D + I5 x4 y - 10 x2 y3 + y5 M a@2, 2D=
We get one representation equation for each polynomial : repEqs = Thread@left == rightD :-
1
3 x5 +
5 x4 y
3 x3 y2 - 5 x2 y3 -
5
3 x y4 +
y5
2 2 2 2 Ix5 - 10 x3 y2 + 5 x y4 M a@1, 1D + I5 x4 y - 10 x2 y3 + y5 M a@2, 1D,
-
x5
-
5
+5
3 x4 y + 5 x3 y2 + 5
3 x2 y3 -
5 x y4
-
3 y5
Ix5 - 10 x3 y2 + 5 x y4 M a@1, 2D + I5 x4 y - 10 x2 y3 + y5 M a@2, 2D> 2
2
2
2
Use SolveAlways to make the representation matrix Can we solve these equations? First we try our old friend, the Solve operator: vars = Variables@basisD 8x, y<
Solve@repEqs, aList, varsD 88<<
The empty bracket means that we did not pose a proper problem for Solve. We asked it to solve two equations for four variables (aList), with the elimination of three variables ({x,y,z}). When you put it this way, you can see why Solve considered the problem ill-posed. But a related operator that goes by the name of SolveAlways[eq,vars] is exactly set up for this situation, The Always in its name means “ for all values of the vars”. This operator considers the given equation to be an identity, true for all values of x,y,z , and tries to find values of the parameters in aList that make it so. This is exactly what we want: aRules = SolveAlways@repEqs, varsD Flatten
361
Symmetry Theory
:a@1, 1D ® -
3
, a@1, 2D ® -
2
1
, a@2, 1D ®
2
1
, a@2, 2D ® -
2
3 2
>
Those are the right answers, in a simple List. As a matrix they are mat = aMat . aRules; % GridForm 3
-
2 1 2
- 12 -
3 2
Check the mat by putting it back into the definition of representation : Expand@basis . rule2D == Expand@basis.matD True
The procedure above will become MakeMatPoly[], which makes the rep mat for one rule. Then another operator MakeRepPoly[] will map it onto all the rules, producing the whole representation Click into the package to see the details. Here is its thumbnail syntax statement : MakeRepPoly[basisList,gp(,opt)] returns a matrix representation of group gp using the Cartesian polynomials in basisList as the basis functions. Option Report®True causes each matrix to be printed out as it is calculated. See Chapter 27 (MakeReps).
Click into the End Notes to see it tested. Perhaps you would like to stop here and go to the next chapter. The rest of this chapter is similar to what you have just seen. It details three different methods of solving Eq. 27.1 (the master representation equation); namely, for f objects that are matrices, atomic orbitals, or molecular orbitals.
27.3 Matrix basis (Ix, Iy, Iz) Closed; please read from CD
27.4 Atomic orbital basis Closed; please read from CD
27.5 Molecular orbital basis 362
Closed; please read from CD
List
27.5 Molecular orbital basis Closed; please read from CD
27.6 Check the characters of the reps Matrix representations like those that we have constructed here will find their main use later on in the projection operators. However, the simplest thing we can do with them is just to check that their class characters agree with those in the character table. Below, we use MakeRep operators to get concrete representations, and then we take the traces : TabulatedBases@"D3h"DP3T :E¢ , :8x, y<, :
Ix2 - y2 M, x y>>>
1 2
repxzyzD3h = MakeRepPoly@8x z , y z <, "D3h"D; MatrixList@%D Size@6D :
1 0 0 1
,
1
3 2
-1 0 0 -1
,
3
-
2
-
-
2
,
1
-
2
1
3
2
2
-
1
3
2
2 3
-
2 1
,
1
-1 0 0 1
-
3
1
3
1
2
2
2
2
3 2
,
1 0 0 -1
3
-
2
,
3
-
2
,
2
-
2
1
,
2
,
1
3
2
2
1
3
2
2
1
3
2
2
3
1
2
2
, -
-
1
2
-
2
,
1
3
1
2
2
3 2
>
Apply the Spur operator (which takes the trace, or diagonal sum): longVecD3h = Map@Spur, repxzyzD3hD 82, -1, -1, 0, 0, 0, -2, 1, 1, 0, 0, 0<
This gives a list of characters as long as the group itself. Check the diagonal sum by eyeball examination. As advertised, every element within a class has the same Spur (diagonal sum). Take out the redundancy : ChVecE¢ = OnePerClass@longVecD3h, "D3h"D 82, -1, 0, -2, 1, 0<
This checks with the character table. But the table says that species E¢¢ can also be constructed using matrices {Ix,Iy}. So do it : repIxIyD3h = MakeRepRot@8Ix, Iy<, "D3h"D; MatrixList@%D Size@6D
363
Symmetry Theory
:
1 0 0 1
,
1
3 2
-1 0 0 -1
,
3
-
2
-
-
2
,
1
-
2
1
3
2
2
-
1
3
2
2 3
-
2 1
,
1
1 0 0 -1
,
2
-
2
,
3
1
3
1
2
2
2
2
3 2
1
3
2
2
3
1
2
2 1
,
-1 0 0 1
,
3 2
1
-
-
2
-
3
1
2
2
3
-
2
-
,
2
,
3 2
,
1
3
2
2
1
3
2
2
-
>
1 2
Are the two representations, {x z,y z} and {Ix,Iy}, the same? repxzyzD3h == repIxIyD3h False
Nothing said they had to be, and they are not. But the characters had better be the same : OnePerClass@Map@Spur, repIxIyD3hD, "D3h"D == ChVecE¢ True
They are. On your own Call up the BoxedCharacterTable and compare the characters. Then do some examples of you own on other groups.
The leftmost character, the character of class E, is the dimension of the representation . Click back to Chapter 14 to be reminded why.
27.7 End Notes 27.7.1 A complex numerical rep ( Eu,a of Th ) The 1-D numerical rep algorithm is simple, but when it produces complex numbers it needs some extra attention. Group Th has four complex-valued onedimensional reps. We will work with the Eua species. tabulatedEuaRow = CharacterTable@"Th"DP8T; % Size@8D
364
End Notes
:Eua, :1, -
1 -
ä
2
3
1 ,-
2
+
ä
2
::x y z x2 + y2 - ä
3
1 , 1, -1,
2
3 Ix2 - y2 M - 2 z2 >>>
+
ä
3
1 -
,
2
2
ä
2
3 , -1>, 2
EuaFn = tabulatedEuaRowP3, 1, 1T x y z Jx2 + y2 - ä
3 Ix2 - y2 M - 2 z2 N
Try the one-function algorithm on it : repRaw =
EuaFn . SymmetryRulesInverse@"Th"D
Short@%, 6D :1,
;
EuaFn
-2 x2 + y2 + z2 - ä x2 + y2 - ä
3 Iy2 - z2 M
3 Ix2 - y2 M - 2 z2 3 Iy2 - z2 M
-2 x2 + y2 + z2 - ä
3 Ix2 - y2 M - 2 z2
x2 + y2 - ä
,
, 18, -1, -1, -1>
This looks like a total failure. Each result is supposed to be just a number, but many are not. But don't despair; it just needs more simplification. Below, we do it, and also shorten the result by using OnePerClass on it: repEuaOfTh = repRaw FullSimplify ComplexExpand; chsEuaOfTh = OnePerClass@repEuaOfTh, "Th"D :1, -
1 2
-
ä
3 2
,-
1 2
+
ä
3
, 1, -1,
2
1 2
+
ä
3
1 ,
2
2
-
ä
3
, -1>
2
This agrees with the tabulated characters:
chsEuaOfTh == HtabulatedEuaRowP2T ComplexExpandL True
27.7.2 The smart rules for complex symbols In the Boxed version of the character table the complex numbers are represented by Ε and several of its variants that humans are used to seeing; namely, -Ε, Ε* , -Ε* , ä Ε, -ä Ε, -ä Ε* , ä Ε* . Translating complex numbers into these symbols is highly prone to human error, so it has been automated by a tricky little operator SmartRules tucked away somewhere in the Symme try` package :
365
Symmetry Theory
Εvalue = Exp@-2 Π ä 3D ComplexExpand -
1
-
ä
2
3 2
Clear@ΕD; ΕRules = SmartRules@Εvalue, ΕD :-
1
-
ä
2 1
+
ä
2 ä 2
-
3
® Ε,
2
2
+
ä
3
2 3
® Ε* ,
2 3
1
1
-
ä
2 ® -ä Ε,
ä 2
® -Ε,
2
+
3
® -Ε* , -
2 3
ä 2
® -ä Ε* , -
2
ä 2
3
+
-
® ä Ε,
2 3 2
® ä Ε* >
Here is the character row presented in the BoxedCharacterTable : chsEuaOfTh . ΕRules
81, Ε, Ε* , 1, -1, -Ε, -Ε* , -1<
On your own All cyclic groups with more than two elements have complex characters. Do some further examples using the model above.
27.7.3 A few tests of MakeRepPoly The step-by-step development was done in the main text. Here we test the package version. A one-dimensional representation A2u of D3d TabulatedBases@"D3d"DP5T 9A2u, 98z<, 93 x2 y - y3 ===
repA2uofD3d = MakeRepPolyA93 x2 y - y3 =, "D3d"E 8881<<, 881<<, 881<<, 88-1<<, 88-1<<, 88-1<<, 88-1<<, 88-1<<, 88-1<<, 881<<, 881<<, 881<<<
MorphTest@repA2uofD3d, "D3d"D
slotð1 represents slotð2 unfaithfully HhomomorphismL
366
End Notes
A two-dimensional representation Eu of D3d TabulatedBases@"D3d"DP6T :Eu, :8x, y<, :
Ix2 - y2 M z, x y z>>>
1 2
repEuofD3d =
Ix2 - y2 M z, x y z>, "D3d"F; 2 % MatrixList Size@6D 1
MakeRepPolyB:
:
1 0 0 1
, -
-1 0 0 -1
,
1
3
2
2 3
-
2
,
3
2
2 3
2
2
3
-
2
1
1
-
1
-
2
1
3
2
2
1
3
2
2
1
-
2
,
,
3 2
,
-
1
1
-
2
1
3
2
2
3
1
3
1
3
1
2
2
2
2
2
2
,
3
-
2
,
3 2
-
1 0 0 -1
2
-1 0 0 1
,
1
,
2
,
1
-
2
-
3
1
2
2
3 2
>
MorphTest@repEuofD3d, "D3d"D
Faithful, or Isomorphic
Map@UnitaryQ, repEuofD3dD Union
8True<
A one-dimensional complex representation Ea of T TabulatedBases@"T"DP2T :Ea, ::-x2 - y2 - ä
3 Ix2 - y2 M + 2 z2 >>>
repEaofT =
3 Ix2 - y2 M + 2 z2 >, "T"F
MakeRepPolyB:-x2 - y2 - ä
Expand OnePerClass@ð, "T"D &
:881<<, ::-
1
-
ä
2
3 2
>>, ::-
1
+
2
ä
3 2
>>, 881<<>
This agrees with the tabulated characters :
CharacterTable@"T"DP4, 81, 2
1 2
-
ä
3 2
,-
1 2
+
ä
3 , 1>> 2
A three-dimensional representation, T of T 367
Symmetry Theory
A three-dimensional representation, T of T TabulatedBases@"T"DP4T
8T, 88x, y, z<, 8x y, y z, x z<, 8Ix, Iy, Iz<<<
repTofT = MakeRepPoly@8x y, y z, x z<, "T"D; % MatrixList Size@6D 1 0 0 : 0 1 0 0 0 1
,
0 0 -1 1 0 0 0 -1 0
0 1 0 0 0 1 1 0 0
,
0 -1 0 0 0 -1 1 0 0
0 0 1 -1 0 0 0 -1 0
,
,
,
0 0 1 1 0 0 0 1 0
0 1 0 0 0 -1 -1 0 0
,
,
-1 0 0 0 1 0 0 0 -1
0 -1 0 0 0 1 -1 0 0
,
,
-1 0 0 0 -1 0 0 0 1
0 0 -1 -1 0 0 0 1 0
,
,
1 0 0 0 -1 0 0 0 -1
>
MorphTest@repTofT, "T"D
Faithful, or Isomorphic
Map@UnitaryQ, repTofTD Union
8True<
A five-dimensional representation H of I This is the longest and hardest representation in our tabulated groups, 60 matrices of size 5´5. The polynomial basis for rep H of group I is TabulatedBases@"I"DP5T; % Size@8D :H, ::
-x2 - y2 + 2 z2
1 ,
2
3
2
Ix2 - y2 M, x y, y z, x z>>>
Construction of rep H takes about 40 seconds on an 867 MHz G4, so we block automatic evaluation below. If you want to see it run, select the cell bracket, go to Cell(menu) > CellProperties and click Evaluatable. Then run it. H*NOT EVALUATABLE*L
8timeHofI, repHofI< = MakeRepPolyB:
-x2 - y2 + 2 z2 2
3
Ix2 - y2 M, x y, y z, x z>, "I"F Timing; 2 timeHofI Short@repHofI, 8D 1
Here is one matrix from rep H: 368
1 0
repHofIP59T//MatrixForm//Size[5]
0
0
0
,
End Notes
Here is one matrix from rep H: repHofIP59T//MatrixForm//Size[5]
1 0
0
1
1
1
2
2
0
-1 +
5
4
0
1
1
2
2
0 0
5+
5
1
1-
5+
5
5
0
0
0
0
0
0
4
0
1
1+
1
5
4
0 0
0
1
2 5+
5
-
10 5 +
5
8
2 5+
5
-
10 5 +
5
8
1
-1 -
5
4
The radicals of radicals are not dealt with very effectively by Simplify, and this limits what can be done in infinite precision. But often you can speed things up by handling it numerically. But even that takes 9 Second : H*NOT EVALUATABLE; JUST READ THE RESULT*L MorphTest@repHofI, "I", Numeric ® TrueD Timing Faithful, or Isomorphic
88.9924 Second, Null<
(*NOT EVALUATABLE; JUST READ THE RESULT*) Map[UnitaryQ,repHofI//N]//Union {True}
27.7.4 Development of MakeRepRot Closed; please read from CD
27.7.5 Tests of MakeRepAtomic Closed; please read from CD
369
28. Reducible representations Preliminaries
28.1 The Cartesian representations The geometrical transforms embodied in the Cartesian representations (or CartReps) of each group take point {x,y,z} and turn it into a geometrically related point. This is just a special case of a functional transform in which the transformed functions 8f1 , f2 , f3 < are the axes themselves {x,y,z}. Here is a feature of the Cartesian representations that is common to all the axial groups, but not to the Platonic groups. Look at one of the axial groups : Map@MatrixForm, CartRep@"D3"DD Size@5D
1 0 0 : 0 1 0 , 0 0 1
-
1
3
-
-
0
2
2
1
3
2
2
3 2 0
-
1
2 0
0 1
-
0
,
, -
3 2 0
-
1
2 0
0
1 0 0 0 -1 0 , 0 0 -1
1
1
3
2
2
-
0
1
3
-
2
0 2
, 3
1
2 0
2 0
All these matrices are in block diagonal form,
0
-
-1
Ì Ì Ì Ì
3
1
2 0
2 0
0 0 .
>
0 -1
This occurs
0 0 Ì because both proper and improper z-axis rotations mix x and y together. They may change the sign of z, but they never mix it with anything. The same may be said of twofold rotations about axes perpendicular to z, and of reflections parallel or perpendicular to z. This covers all the symmetry elements not in the Platonic groups. On your own Pull up some other CartReps of non-Platonic groups and note their block diagonal form. Now we will show that the upper and lower blocks are separate representations of the group. Pull out the D3 table and note that z is a basis for species A2 . repz = MakeRepPoly@8z<, "D3"D; % Flatten 81, 1, 1, -1, -1, -1<
Never assume it is a rep without testing :
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_28, © Springer Science+Business Media, LLC 2009
371
Symmetry Theory
MorphTest@repz, "D3"D
slotð1 represents slotð2 unfaithfully HhomomorphismL
Compare repz to the 3,3 elements of the tabulated CartRep for D3 : Map@ðP3, 3T &, CartRep@"D3"DD
81, 1, 1, -1, -1, -1<
So the lower right block (1 ´ 1) is a rep by itself. Now make the rep based on {x,y} : repxy = MakeRepPoly@8x, y<, "D3"D; % MatrixList Size@6D :
1 0 0 1
,
1
3
-
2 3 2
2
-
,
1
-
2
1
3
2
2
3 2
-
1
,
1 0 0 -1
2
1
3
2
2
3
1
2
2
,
-
1 2
, -
3
-
2
3
1
2
2
>
MorphTest@repxy, "D3"D Faithful, or Isomorphic
Compare this with the upper left SubMatrix of CartRep["D3"]: repxy == Map@Take@ð, 2, 2D &, CartRep@"D3"DD True
So CartRep["D3"] is of {2 ´ 2,1 ´ 1} block diagonal form.
28.2 Block diagonal multiplication The block diagonal matrices have zeroes everywhere except in square blocks located on the diagonal. They have an interesting property: when you multiply two block diagonal matrices that have the same pattern, the product has the same pattern as its parents. You could say that block structure comes down in the bloodline of matrices. Here are two simple matrix products : :
1 1 2 2 . 1 1 2 2
8True, True<
==
4 4 , 4 4
3 3 3 1 1 1 3 3 3 . 1 1 1 3 3 3 1 1 1
==
9 9 9 9 9 9 > 9 9 9
Put them into a 5 ´5 matrices with a 2 ´2 block in the upper left and a 3 ´3 block in the lower right; then multiply the two big matrices together :
372
Block multiplication
1 1 0 0 0
1 1 0 0 0
0 0 3 3 3
0 0 3 3 3
0 2 2 0 2 2 3 . 0 0 3 0 0 3 0 0
0 0 1 1 1
0 0 1 1 1
0 0 1 1 1
==
4 4 0 0 0
4 4 0 0 0
0 0 9 9 9
0 0 9 9 9
0 0 9 9 9
True
As you see, the diagonal blocks multiply independently. Do a few row-bycolumn sums outside the diagonal blocks, and you will see why the block pattern has to reproduce itself. Or, if you want a symbolic argument, here it is: Let a diagonal block start at {Λ,Λ} and end at {Μ,Μ}. Then any row-bycolumn product that intersects within the block can be decomposed into three summands: before + inside + after, Symbolically, HA.BLi,k = â Ai,j Bj,k + â Ai,j Bj,k + â Ai,j Bj,k Λ-1
Μ
N
j=1
j=Λ
j=Μ+1
But in the first sum all the Ai,j are zero (they are all left of the block), and in the third sum all the Bj,k are zero (being above the block). So we are left with HA.BLi,k = 0 +â Ai,j Bj,k +0 Hfor i and k in the diagonal blockL Μ
j=Λ
In words, each product element within the block is given by the matrix product of the blocks. This proves it when i,k is in the diagonal block. Now consider a case when i,k is outside any of the diagonal blocks. For instance, the blue row times the blue column below gives the outside blue zero on the right : 1 1 0 0 0
2 2
1 1 0 0 0
2 2
0 0 3 3 3 0 0 3 3 3 0 0 3 3 3
. 0 0 0 0 0 0
0 0 1 1 1
0 0
4 4 0 0 0
0 0 1 1 1 1 1 1
==
4 0 0 0
4 0 0 0 0 9 9 9 0 9 9 9 0 9 9 9
It is zero because one of the factors in the Dot product is always zero: {1,1,0,0,0}. {0,0,1,1,1} == 0 This could be made into a proof, but it would be too boring. I think you have the idea. Here is the theorem:
373
Symmetry Theory
If Ai and Bj are square blocks on the diagonal, and if the 0's are appropriate blocks of zeroes, then the block diagonal product is A1 0 0 B1 0 0 0 A2 0 0 B2 0 . == 0 0 A3 ¼ 0 0 B3 ¼ »
»
A1 .B1 0 0 0 A2 .B2 0 0 0 A3 .B3 ¼ »
So q.e.d., in a sloppy way. There is more on this in the Matrix Review.
28.3 Reducible and irreducible representations If a block diagonal representation is subjected to a similarity transform, the block diagonal pattern is generally destroyed, but the matrices continue to represent the group quite nicely (click for proof). Usually, we are much more interested in the inverse of this process. In Chapter 30 (Schur'sReduction) (click for preview), we will show how to take a tangled non-block representation and transform it to block diagonal form, using only information from within the tangled representation itself. It's almost like a command to make shattered pottery come back together. Discussion of these matters inevitably involves the following words Reducible representation A representation is reducible if there exists a similarity transform that puts it in block diagonal form. But this is not always possible : Irreducible representation A representation for which no block-diagonalizing similarity transform exists is called an irreducible representation.
374
Mulliken names
28.4 Mulliken names of irreducible representations The symmetry species, or irreducible representations, are so important that they have been given standard names, called Mulliken names, after the great chemical theorist R. S. Mulliken. These names are used uniformly throughout the spectroscopic literature. They appear down the left column of every Boxed CharacterTable. Here are the rules for these names: 1. One dimensional reps are called A or B; two-dimensional, E; three dimensional T or F, four dimensional, G; five-dimensional, H. Exception: One dimensional reps that come in conjugate pairs act spectroscopically like E reps, and they are called Ea and Eb . 2. One-dimensional reps have a name anchored on A or B. If the character for rotation about the principal axis by the smallest angle is 1, the anchor is A; if -1, the anchor is B. Exception: In group D2 , there is no unique principal axis, all the nontrivial reps are called B. 3. The anchor gets a subscript 1 if rotation about a two-fold axis in the x,y plane has character 1, or lacking that, if reflection in a vertical plane has character 1. The subscript is 2 if the character is -1. (Again, group D2 has to be exceptional.) 4. The anchor gets a single prime if the rep has character 1 for reflection in the x,y plane. If the character is -1, a double prime. 5. The anchor takes a subscript g (German gerade) if the character for inversion is 1; it takes a u (German ungerade) if -1. 6. Several groups have multiple E or T reps, some with adornments as above. These are subscripted by 1, 2, … just to distinguish them. The irreducible representation names are also called species names, a much shorter and more descriptive way of speaking. We use “irreducible representations” and “species” quite interchangeably in this book. The word “species” should bring to mind a characteristic nodal pattern seen in the ContourPlot of the basis functions. You have already seen many examples of irreducible representations. All the representation bases listed in the character tables produce irreducible representations. (That's why they are there.) Proving them irreducible is another matter; but curiously, there is a simple algorithm invented by I. Schur that performs the reduction very easily. We will study it in Chapter 30 (SchursReduction). But first, as motivation, you should see an example of a big reducible representation, and see what you learn by reducing it. 375
28.5 Example: the rep of the benzene orbitals
Symmetry Theory
28.5 Example: the rep of the benzene orbitals 28.5.1 Construct the representation If you need to remind yourself how to make a representation on the basis of atom permutations of a symmetric molecule, click back to the step-by-step construction in Chapter 27 (MakeReps). Here we do it by simply invoking the operator MakeRepAtomic, developed in that chapter : 8repBzΠ, AOsToCart< = MakeRepAtomic@"benzene", "D6h", atomKind ® "C", preFactor ® zD; repBzΠP82, 3, 4
0 1 0 : 0 0 0
0 0 1 0 0 0
0 0 0 1 0 0
0 0 0 0 1 0
0 0 0 0 0 1
1 0 0 , 0 0 0
0 0 0 0 0 1
1 0 0 0 0 0
0 1 0 0 0 0
0 0 1 0 0 0
0 0 0 1 0 0
0 0 0 , 0 1 0
0 0 1 0 0 0
0 0 0 1 0 0
0 0 0 0 1 0
0 0 0 0 0 1
1 0 0 0 0 0
0 1 0 > 0 0 0
Even though you have only rep mats 2, 3, and 4 above you can see that the pz representation is NOT in block diagonal form. The D6 h character table says that the largest irreducible representation is of size 2 ´ 2, so this is certainly not an irreducible representation. By linguistic reasoning then, it must be “reducible”. Check immediately that it is a representation of D6 h : MorphTest@repBzΠ, "D6h"D Faithful, or Isomorphic
Is it unitary?
Map@UnitaryQ, repBzΠD Union
8True<
Make its character vector : Χ@repBzΠD = OnePerClass@Map@Spur, repBzΠD, "D6h"D 86, 0, 0, 0, 0, -2, 0, 0, 0, -6, 2, 0<
This example presents the remaining questions of representation theory in a very concrete form. These 24 representation matrices contain every bit of information about how these six atomic pz orbitals transform under D6 h . But these orbitals span a 6-dimensional function space that contains all the LCAO Π molecular orbitals of benzene, so when we study this function space, we are studying the benzene Π MO's. How can we characterize this six-dimensional 376 space in a simple and understandable way that tells us something about benzene?
This example presents the remaining questions of representation theory in a very concrete form. These 24 representation matrices contain every bit of information about how these six atomic pz orbitals transform under D6 Benzene h . But
studying the benzene Π MO's. How can we characterize this six-dimensional space in a simple and understandable way that tells us something about benzene?
28.6 Reduction demo We leap ahead to use the operator ReduceRep, not yet derived. We do not disclose the secret construction method until Chapter 30 (SchursReduction); here we just use it. First, make an arbitrary 6 ´6 matrix Qmat: Q mat = 889, 5, 1, 1, 5, 7<, 85, 2, 7, 5, 1, 2<, 810, 5, 7, 2, 1, 4<, 85, 3, 9, 3, 6, 4<,
88, 9, 3, 1, 6, 4<, 89, 6, 7, 5, 8, 7<<;
You may think it surpassing strange that the ReduceRep operator requires an arbitrary matrix as part of its input. But that is the fact. We apply it and look at two of the resulting matrices: blockRepBz = ReduceRep@repBzΠ, Q matD; %P82, 3
0
0
1
3
2
:
0
3
-
0
0
0
0
0
0
2 3
0
0
0
0
-1
0
0
0
0
0
0
0
1
1
0
0
0
0
2
0
2
1
2
0
0
-
1
3
2
2
3 2
-
1
0 ,
0 3
-
0
0
0
0
0
0
2 1
0
0
0
2
2
0
0
0
-1
0
0
0
0
0
0
-
1
3
-
2
0
0
0
0
2
3 2
>
2
-
1 2
Something rather marvellous has happened. They have been subjected to a clever similarity transform, that turned them all into block diagonal form; blocks of size 1, 2, 1, and 2. Interactive readers can see all 24 rep matrices. As we have said elsewhere, similarity transforms change the costumes in which a representation appears, but underneath it is the same old troupe of clowns, performing the same old show. Check it : MorphTest@repBzΠ, blockRepBzD Faithful, or Isomorphic
The character of each clown is always the same, regardless of his costume : OnePerClass@Map@Spur, blockRepBzD, "D6h"D == Χ@repBzΠD True
377
28.7 What is the point of rep reduction?
Symmetry Theory
28.7 What is the point of rep reduction? 28.7.1 Identification of the blocks We can find out a lot about the six Π orbitals of benzene by finding the names the four irreducible representations in the blocks. If we know the names, we can look up the supporting basis functions in the character table, and these will give us important facts about the benzene orbitals. Look at the character table to see how many irreducible reps are possessed by D6 h : BoxedCharacterTable@"D6h"D D6h
1
2
E
C6 C3 C2
2
1
3
3
1
A1g
1
1
1
1
1
1
A2g
1
1
1
1 -1 -1
B1g
1 -1
1 -1
B2g
1 -1
1 -1 -1
E1g
2
E2g
2 -1 -1
1 -1 -2 2
2
2
1
3
3
C¢2 C¢¢ 2 inv S3 S6 Σh Σd Σv 1
1
1
1
1
1
-1
1 -1
1
1
-1
1 -1 -1
0
0
2
1
0
0
2
1 -1 -2 -1 -1
9I x2 + y2 M, I z2 M= Basis functions
1 -1 -1 9I x y Ix2 - 3 y2 M I-3 x2 + y2 M M, H Iz
1
1 -1
¬ Class populations
2
1
1
1 -1 1
9I x Ix2 - 3 y2 M z M=
9I y I-3 x2 + y2 M z M=
0
0
:K
0
0
:
xz O, yz 1 2
Ix > Iy
Ix2 - y2 M
>
9I x y Ix2 - 3 y2 M I-3 x2 + y2 M z M xy
A1u
1
1
1
1
1
-1
-1 -1 -1 -1 -1
A2u
1
1
1
1 -1 -1
-1
-1 -1 -1
B1u
1 -1
1 -1
B2u
1 -1
1 -1 -1
E1u
2
E2u
2 -1 -1
1 -1 -2 2
1
1 -1
1
1 1
-1
1 -1
1 -1
1
-1
1 -1
1
1 -1
0
0
-2
-1
2
0
0
0
0
-2
1
1 -2
0
0
1
8H z L<
9I y I3 x2 - y2 M M=
9I x I-x2 + 3 y2 M M= :K
:
1 2
x O> y
Ix2 - y2 M z
>
xyz
Group D6 h has 12 irreducible reps, but we already know from the block diagonal form that only four contribute to the benzene pz rep. Which ones are they? We are going to lift out the four blocks and test them one at a time to see if they are irreducible reps given in the character table. This is a conceptually simple method for identifying the irreducible reps contained in the reducible representation, but not the one used in practice. But that quick and easy method depends on a long chain of theorems, and we cannot logically present it yet. To peek ahead, click to Chapter 35 (RepAnalysis).
378
Why reduce?
Block {1,1} in blockRepBz To test the blocks, we need a way to lift them out. Fortunately, the operator Take does exactly what we need, if supplied with the right options. Click to the End notes for a demo. Use it on the 1 ´ 1 rep in the upper left : rep11 = Map@Take@ð, 1, 1D &, blockRepBzD Flatten 81, 1, 1, 1, 1, 1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 1, 1, 1, 1, 1, 1<
This is the whole 24-element representation, and since the rep is one-dimensional, it is also a list of all the characters. Since all elements in the same class have the same character, we lift out just the first character in each class : Χ11 = rep11 OnePerClass@ð, "D6h"D &
81, 1, 1, 1, -1, -1, -1, -1, -1, -1, 1, 1<
Does this match any character in the table for D6 h ?
Select@CharacterTable@"D6h"D, HðP2T == Χ11L &D
88A2u, 81, 1, 1, 1, -1, -1, -1, -1, -1, -1, 1, 1<, 88z<<<<
Yes; it is species A2 u , which transforms like z. The symmetry of function z is exactly the symmetry of the lowest energy pz orbital, in the sense that they both have a node at z = 0. On your own We have now shown that block 1 is A2 u . Show in a similar way that block 2 is E1 g , 2 is B1 g , and 4 is E2 u . A2 u 0 0 E1 g
0 0
0 0
0
0
B1 g
0
0
0
0
E2 u
Click for help. So we have the orbital labels in Fig. 23. 5. In order of increasing energy, the species are A2 u (one nodal plane), E1 g (two nodes), E2 u (three), and B1 g (four).
379
Symmetry Theory
Contour plot The B1 g basis function is given in the character table as x Ix2 - 3 y2 M z . Here is its x,y contour plot at height z = 1 :
grph1 = ContourPlotAx3 - 3 x y2 , 8x, -1, 1<,
8y, -1, 1<, FrameTicks ® None, ImageSize ® 120, ColorFunction ® BlueShades, PlotLabel ® "B1 g "E
B1 g
Fig. 28.1 The tabulated polynomial for B1 g of D6 h
Click back to the contour plots of the benzene orbitals to compare. You may be quite astonished. You may begin to see the true significance of the polynomial basis functions given in the character tables.
28.7.2 Implications for spectroscopy These results explain the labels A2 u , E1 g , E2 u , and B1 g in Fig. 23.1, the contour plots of the benzene Π orbitals (found in principle by an accurate solution of one-electron Schrödinger equation). We could not justify those names in Chapter 23, but now we see that the accurate eigenstates are basis functions for these four irreducible representations of D6 h . The basis of all electronic state notation in spectroscopy is the use of irreducible representation names for Schrödinger eigenstates that transform like the representation. For instance, if a molecule has two observed electronic states that transform like the irreducible representation Au , they will be named 1 Au (the lower), 2 Au (the higher). Note that in this chapter we never found the molecular orbitals explicitly or exactly. We worked only with the atomic orbitals that span a space of approxi380 mate molecular orbitals. But nevertheless, we reached definite, detailed conclusions about the “exact” benzene orbitals.
Why reduce?
Note that in this chapter we never found the molecular orbitals explicitly or exactly. We worked only with the atomic orbitals that span a space of approximate molecular orbitals. But nevertheless, we reached definite, detailed conclusions about the “exact” benzene orbitals. Group theory cannot give quantitative energies, but it does give the energy ordering of the orbitals. Benzene's Π orbitals all have a pz node in the molecular plane, but the number of additional nodes (perpendicular to the z = 0 plane) is 0 for A2 u , 1 for E1 g , 2 for E2 u , and 3 for B1 g , just as it is in the simple polynomial basis functions for these reps. Each additional node costs energy, so the increasing energy order must be A2 u , E1 g , E2 u , B1 g . Further, group theory predicts that the corresponding degeneracy pattern is 1, 2, 2, 1. With six Π electrons and two electrons per orbital, the filled orbitals in the ground state can only be the A2 u and the two E1 g . The lowest spectroscopic transitions must therefore be from somewhere in twofold degenerate level E1 g to somewhere else in twofold degenerate level E2 u
KΑ ΨE1gA +Β ΨE1gB O ® JΓ ΨE2uA +∆ ΨE2uB N
where the coefficients Α, Β, Γ, ∆ would be picked by an intrinsic quantum uncertainty process. But this refers only to one electron hovering around six fixed attractive centers. In real benzene, six Π electrons are present and we must add electron-electron repulsion terms to the Hamiltonian. The degeneracies then vanish and we must consider four nondegenerate transitions ΨE1gA ®ΨE2uA , ΨE1gA ®ΨE2uB , ΨE1gB ® ΨE2uA , and ΨE1gB ®ΨE2uB . Three of these have been definitely identified in the spectroscopy of benzene. The fourth and highest was a puzzle for many years, but it is now known to be mixed into a broad continuum of the same symmetry above ionization, and is therefore unobservable as an isolated vibronic band. (The continuum does not appear in the Π electron treatment, and for years people did not take it into account properly.) As we pursue the benzene example through this book, we will see that this little Π orbital treatment is a very reliable framework for understanding the vibronic spectroscopy of the three resolvable states. The polarization behavior of these states are all predicted as exact results from geometrical symmetry alone, without a single quantitative quantum chemistry calculation.
381
Symmetry Theory
28.8 End Notes 28.8.1 Lifting out submatrices with Take The operator Take has the ability to lift submatrices out of larger matrices.
G=
a e i m
b f j n
c g k o
d h ; l p
Take@G, 2, 3D GridForm a e
b f
c g
The 2 told it to take the first two rows; the 3 said to take the first three columns. Now tell it to take the upper left 3 ´3 : Take@G, 3, 3D GridForm a e i
b f j
c g k
To lift out from the interior of the matrix you must apply Take twice: Take@Take@G, 3, 3D, -2, -2D GridForm f j
g k
28.8.2 Species of the four blocks in blockRepBz We condense the three operations from the main text into one cell. For all the matrices in the group, we (1) lift out the block, (2) calculate the character vector, and (3) Select a line from the character table that contains a matching vector. Map@Spur, Map@Take@ð, 1, 1D &, blockRepBzDD; OnePerClass@%, "D6h"D; Select@CharacterTable@"D6h"D, HðP2T == %L &D
88A2u, 81, 1, 1, 1, -1, -1, -1, -1, -1, -1, 1, 1<, 88z<<<<
So block 1 is A2 u . 382
Do the next :
End Notes
So block 1 is A2 u .
Do the next :
Map@Take@Take@ð, 3, 3D, -2, -2D &, blockRepBzD; Map@Spur, %D; OnePerClass@%, "D6h"D; Select@CharacterTable@"D6h"D, HðP2T == %L &D 88E1g, 82, 1, -1, -2, 0, 0, 2, 1, -1, -2, 0, 0<, 88x z, y z<, 8Ix, Iy<<<<
So block 2 is E1 g . Map@Take@Take@ð, 4, 4D, -1, -1D &, blockRepBzD; Map@Spur, %D; OnePerClass@%, "D6h"D; Select@CharacterTable@"D6h"D, HðP2T == %L &D 99B1g, 81, -1, 1, -1, 1, -1, 1, -1, 1, -1, 1, -1<, 99x Ix2 - 3 y2 M z====
So block 3 is B1 g . Map@Take@ð, -2, -2D &, blockRepBzD; Map@Spur, %D; OnePerClass@%, "D6h"D; Select@CharacterTable@"D6h"D, HðP2T == %L &D ::E2u, 82, -1, -1, 2, 0, 0, -2, 1, 1, -2, 0, 0<, ::
1 2
Ix2 - y2 M z, x y z>>>>
So block 4 is E2 u .
383
29. The MakeUnitary operator Preliminaries
29.1 Unitary and non-unitary reps All our tabulated CartReps are made of unitary matrices. Click on the blue if this term is a little hazy to you. As a basic reminder, unitary means that the inverse is equal to the transpose. Several theorems in the chapters ahead use the assumption that the rep in question is unitary. This shortens the theorem significantly, but does it restrict the validity of the theorem? This chapter says no; if you have a non-unitary rep it can always be made unitary by a similarity transform, and then you can work with it using the assumption that it is unitary. Linguistic note: When we say "then you can work with it" , we have slipped into language where two reps related by a similarity transform are “ the same” (and can both be referenced by the same "it") even though they are not literally mathematically equal. Mathematicians talk this way all the time. Click into the MatrixReview for a discussion of why they do this.
29.1.1 Make a rep non-unitary by a similarity transform In this chapter you will see some non-unitary representations. It's not that they are useful; in fact we try to avoid them. The whole point of this chapter is to show how to get rid of them. But first we have to show how non-unitary reps can arise. We begin with a nice little unitary representation : xyRepD3 = MakeRepPoly@8x, y<, "D4"D; Map@MatrixForm, %D Size@7D :
1 0 , 0 1
0 -1 , 1 0
0 1 , -1 0
-1 0 , 0 -1
1 0 , 0 -1
-1 0 , 0 1
0 1 , 1 0
0 -1 > -1 0
These matrices are all either symmetric or antisymmetric. It is easy to test a matrix for the unitary property. There is an operator called UnitaryQ[mat] in the Symmetry` package. It simply take the Inverse and the Trans pose of the given mat, and tests them for equality. Test xyRepD3 : Map@UnitaryQ, xyRepD3D
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_29, © Springer Science+Business Media, LLC 2009
385
Symmetry Theory 8True, True, True, True, True, True, True, True<
Now we make a similarity transform of this rep, using a random integer transforming matrix Q: Q= ::
1 102
12
TableARandomIntegerA91, 102 =E, 8i, 2<, 8j, 2<E 7
, 25
100
>, :
73
13 ,
100
20
>>
Qinv = Inverse@QD ::
6500
,-
2609
700 2609
>, :-
7300
4800 ,
2609
2609
>>
Map@UnitaryQ, 8Q, Qinv
8False, False<
To preserve the unitary property of a representation, it must be similarity transformed by unitary matrices (click for proof), But here, perversely, we destroy the unitary property by transforming with nonunitary matrices : NUrep = Map@Q.ð.Qinv &, xyRepD3D; Map@MatrixForm, NUrepD 1 0 :K O, 0 1 3631 2609 9490 2609
3959 2609 9554 2609
672 - 2609
- 3631 2609
,
- 2353 2609 -
3959 2609
- 3959 2609
,
- 3631 2609 - 9490 2609
672 2609 3631 2609
9554 2609
,
2353 2609 3959 2609
- 3049 2609 - 1104 2609
,K
-1 0 O, 0 -1
2255 2609 3049 2609
,
3049 2609 1104 2609
- 2255 2609 - 3049
>
2609
The symmetry (or antisymmetry) of most of the matrices has been lost. No way could a person recognize this as a representation of D3 . Yet it is : MorphTest@NUrep, "D4"D Faithful, or Isomorphic
But is it unitary? Map@UnitaryQ, NUrepD
8True, False, False, True, False, False, False, False<
No; the only unitary matrices are the unit element and its negative. Below, in this chapter, we will develop an operator that will restore the unitary property to this representation, using only information contained in the representation itself.
29.1.2 Non-unitary rep from unbalanced bases 386
Unitary representations
29.1.2 Non-unitary rep from unbalanced bases Another way to make a nonunitary rep is to construct it using “unbalanced” basis functions. For instance, the functions {x,y} support a unitary rep of group D3 . But suppose we “unbalance” the basis by multiplying the y by 2 : x2yRepD3 = MakeRepPoly@8x, 2 y<, "D3"D; Map@MatrixForm, %D Size@8D :
1 0 , 0 1
-
1
-
2
,
3
-
4
1 0 , 0 -1
-
-
3
1 2
1
-
2
-
3 ,
3
1
4
2
-
1
3
2 3 4 1 2
, -
1 2
-
3
3
1
4
2
>
MakeRepPoly did indeed make a representation : MorphTest@x2yRepD3, "D3"D Faithful, or Isomorphic
but its matrices are not unitary : Map@UnitaryQ, x2yRepD3D
8True, False, False, True, False, False<
Projection operators can easily give basis sets for representations, but they will usually come out unbalanced. The balancing operation described in the next section can always cure this problem.
29.1.3 Balancing a basis set In Chapter 27 (MakeReps) we constructed an operator MakeRepMolec that makes representations on the basis of complete sets of molecular orbitals. We used it with a simple set of molecular orbitals, and it produced a representation, but the rep was not unitary. Click back to review. Here we show a simple scheme for balancing the basis functions, in order to make a unitary representation. We use the same basis as before, except that we multiply one of the basis functions by an unknown multiplier k : MObasis = 8k H2 AO@1D - AO@2D - AO@3DL, AO@2D - AO@3D<;
AOsToCart = :
AO@1D ® z fA1 - 2 x + x2 + y2 + z2 E, , 387
Symmetry Theory
3 y + y2 + z2 F,
AO@2D ® z fB1 + x + x2 -
3 y + y2 + z2 F>;
AO@3D ® z fB1 + x + x2 + group = "D3h"; Now make the representation:
testRepk = MakeRepMolec@MObasis, AOsToCart, groupD :881, 0<, 80, 1<<, ::::-
1
1 ,
2
2k 1
>, :-
3k 2 3k
,-
1 2 1 2 1
1
,-
2k
>, :
3k
,-
2
1 2
>>,
>>, 88-1, 0<, 80, 1<<,
1 1 1 3k 1 :: , >, :, - >>, :: , >, : , - >>, 2 2k 2 2 2 2k 2 2 1 1 3k 1 88-1, 0<, 80, -1<<, :: , >, :, >>, 2 2k 2 2 1 1 3k 1 :: , >, : , >>, 881, 0<, 80, -1<<, 2 2k 2 2 1 1 3k 1 1 1 3k 1 ::- , >, : , >>, ::- , >, :, >>> 2 2k 2 2 2 2k 2 2
For some value of k, this rep will be unitary. Apply the unitary criterion to each matrix : remainders = Map@HTranspose@ðD - Inverse@ðDL &, testRepkD :880, 0<, 80, 0<<, ::0, ::0, ::0, ::0, 880, ::0, 880, ::0,
1
+
3k
>, :-
1
+
3k
, 0>>, 2k 2 2k 2 1 3k 1 3k >, : , 0>>, 880, 0<, 80, 0<<, 2k 2 2k 2 1 3k 1 3k >, :+ , 0>>, 2k 2 2k 2 1 3k 1 3k + >, : , 0>>, 2k 2 2k 2 1 3k 1 3k 0<, 80, 0<<, ::0, >, : , 0>>, 2k 2 2k 2 1 3k 1 3k + >, :+ , 0>>, 2k 2 2k 2 1 3k 1 3k 0<, 80, 0<<, ::0, + >, : , 0>>, 2k 2 2k 2 1 3k 1 3k >, :+ , 0>>> 2k 2 2k 2
All these remainders would be zero if the rep were unitary. So Select out all the nonzero entries, and Unionize them to remove redundancies : 388
Unitary representations
the nonzero entries, and Unionize them to remove redundancies : kExprs = Select@Flatten@remaindersD, ð =!= 0 &D Union :
1
3k
-
2k
1
,-
2
+
3k
2k
2
>
If you get inconsistent expressions here, you have made a mistake, and you must find it by prayer and fasting. But these are fine, so we forge ahead: Reduce@kExprs == 0, kD ÈÈ k
1
k-
1
3
3
Either solution will balance it. Take the positive balancing factor : balancedBasis = 1 : H2 AO@1D - AO@2D - AO@3DL, AO@2D - AO@3D>; 3 testRepBalanced = MakeRepMolec@balancedBasis, AOsToCart, groupD; % MatrixList Size@8D :
-
1 0 , 0 1
1
-
2 3
-
2 1
-
2 3
-
2
2
-
2 1
3
-
,
3
-
2
,
1
-
2 1
3
2
2
1
3
2
2
-
3 2
3
1
2
2
,
1 0 , 0 -1
1
3
2
2
3 2
,
1
-
,
1
-1 0 , 0 1
2
-1 0 , 0 -1
-
2 1
3
2
2
3
1
2
2
-
, -
1 2
1
3
2
2 3
1
2
2
-
3 2
3
1
2
2
,
>
MorphTest@testRepBalanced, groupD Faithful, or Isomorphic
Map@UnitaryQ, testRepBalancedD Union
8True<
389
Symmetry Theory
Put in the other balancing solution J-1 On your own
Test and UnitaryQ. CartRep["D3h"].
3 N and test with Morph
Then compare the balanced reps to
29.2 The MakeUnitary theorem 29.2.1 Statement and commentary
Theorem Every matrix representation of a group is similar to a unitary matrix representation. This will be particularly important in proving and using Schur's Lemmas. This chapter ends with a Mathematica operator that changes any rep into a similar unitary rep. Rarely will we really have to do this, but it is nice to have it handy for demonstrations. Also, it encloses all the blather of the theorem itself in a very tiny nutshell.
29.2.2 Proof The first similarity transform The proof is constructive, and requires two similarity transforms. Here we work on the first one. Let the Ai be a set of nonunitary matrices representing finite group A ,of order h, and let H = â Ai .AÖi h
i=1
Then by a Lemma proved in the Matrix Review (click here), each summand of H is hermitian, and therefore, so is H. Therefore (click here) matrix H has real eigenvalues and a set of eigenvectors that are mutually orthonormalizable in the complex sense. Take it that this has been done, and let U be the matrix of orthonormal column eigenvectors. Orthonormality in the complex sense means that UÖ .U is the unit matrix, or that UÖ = U-1 , the definition of unitary. We let d be the diagonal matrix of the eigenvalues of H. The eigenequation is H.U = U.d or d = U-1 .H.U 390 How does the diagonal matrix d relate to the original A matrices?
Then by a Lemma proved in the Matrix Review (click here), each summand of H is hermitian, and therefore, so is H. Therefore (click here) matrix H has real eigenvalues and a set of eigenvectors that are mutually orthonormalizable in the complex sense. Take it that this has been done, and let U be the matrix of MakeUnitary theorem orthonormal column eigenvectors. Orthonormality in the complex sense means that UÖ .U is the unit matrix, or that UÖ = U-1 , the definition of unitary. We let d be the diagonal matrix of the eigenvalues of H. The eigenequation is H.U = U.d
d = U-1 .H.U
or
How does the diagonal matrix d relate to the original A matrices? Ö â Ai .Ai .U h
d = UÖ .H.U = UÖ .
i=1
d = â UÖ .Ai .AÖi .U = â UÖ .Ai .IU.UÖ M.AÖi .U h
h
i=1
i=1
d = â IUÖ .Ai .UM.IUÖ .AÖi .UM h
i=1
We transform the parenthesis on the right using the identity LÖ .MÖ .NÖ == HN.M.LLÖ , giving d = â IUÖ .Ai .UM.JHULÖ .IAÖi M .IUÖ M N h
Ö
Ö Ö
i=1
or since the double dagger is no dagger d = â IUÖ .Ai .UM.IUÖ .Ai .UM h
Ö
i=1
But because U is unitary, U is IUÖ M
-1
, and UÖ .Ai .U is the similarity
transform of Ai by UÖ . We call it Ai : Ai = IUÖ .Ai .UM so that d = â Ai .Ai h
Ö
i=1
The transformed matrices A represent the same group that the A matrices do, because they are just similarity transforms, which preserve the multiplication table of any group. The costumes have changed, but the clowns are the same.
391
Symmetry Theory
Lemma: The d matrices are real and positive For this maneuver we move the element index i up into a square bracket, leaving the subscript area free for Greek row and column indices like Α and Β. In other words, we replace Ai by A@iD Α,Β . (Individual matrix elements, with subscripts, are denoted by plain letters; it is the whole matrices that are denoted by double struck letters.) The individual elements of d are dΑ,Γ : Ö dΑ,Γ = â â A@iD Α,Β A @iDΒ,Γ Λ
h
i=1 Β=1
The off-diagonal elements are zero, so we consider just the diagonal elements Ö * dΑ,Α = â â A@iD Α,Β A @iDΒ,Α = â â A@iD Α,Β A @iDΑ,Β h
Λ
h
i=1 Β=1
Λ
i=1 Β=1
In the rightmost member above we performed the † operation explicitly. We transposed by reversing the row and column indices, and left a * to indicate * complex conjugation. But in this form each summand A@iD Α,Β A @iDΑ,Β is a quantity A@iD Α,Β times its own conjugate, and is therefore real and positive, or at least non-negative. So d is a diagonal matrix with real, non-negative entries down the diagonal, as was to be shown. The second transform Diagonal matrix d has a square root
d found by applying the square root
operator down its diagonal. Matrix d is unique up to a sign ambiguity on each diagonal element. Also, the inverse of a diagonal matrix is found by taking numerical inverses down the diagonal. On your own If this is a new idea to you, try it out on a numerical example with negatives and complex numbers on the diagonal. ComplexExpand may be useful. Compute (
d ).(1/
d ).
Now comes a clever manipulation that moves us toward a second and final similarity transform of the matrices we are trying to make unitary. â Ai .Ai h
d
d.
d
i=1
392
Ö
MakeUnitary theorem
d we have
Multiplying this left and right by 1/ 1 J1
d N . â Ai .Ai .J1 h
Ö
dN
i=1
Remember the rearrangement theorem ? It says that inside a sum over all group elements i you may pick any j and replace Ai by IAj .Ai M. This merely rearranges the sum over i, but does not alter its value. We do so: 1 â Jd-12 .IAj .Ai M .IAj .Ai M .d-12 N h
Ö
i=1
and since IAj .Ai M = JAi .Aj N, Ö
Ö
Ö
1 â d-12 .IAj .Ai M.JAi .Aj N .d-12 h
Ö
Ö
i=1
and moving the sum as far inward as possible 1 d-12 . Aj . â Ai .Ai .Aj .d-12 h
Ö
Ö
i=1
But this sum over i is by definition just the matrix d itself, so Ö
1 d-12 . Aj .d.Aj .d-12 Applying the square root trick again
1 Id-12 .Aj .d12 M.J d12 .Aj .d-12 N Ö
The right member of the dot product above may be rewritten as 1 Id-12 .Aj .d12 M.JId-12 M .Aj .Id12 M N
Ö Ö
Ö
But both d12 and d-12 are symmetric and real, so the dagger operation leaves them the same. Therefore 1 Id-12 .Aj .d12 M.Id-12 .Aj .d12 M
Ö
Now we have it. The parentheses contain a second similarity transform of the group, so we let it be a double-barred A with element index j : Aj = d-12 .Aj . d12
Thus we have
1 Aj .Aj
Ö
for every element j in the group.
This is the
defining property of a unitary matrix, and the A matrices still represent the group because they are nothing but a double similarity transform of the original 393 representation. So every representation is similar to a unitary representation, as was to be proved.
Symmetry Theory
Thus we have
1 Aj .Aj
Ö
for every element j in the group.
This is the
defining property of a unitary matrix, and the A matrices still represent the group because they are nothing but a double similarity transform of the original representation. So every representation is similar to a unitary representation, as was to be proved.
29.3 The operator MakeUnitary We have collected all the essential steps from the proof above into one operator, called MakeUnitary , kept in Symmetry`. The "?" returns MakeUnitary[rep_] returns a list of two objects : (1) the left matrix of a similarity transform, and (2) a unitary rep equivalent to the given rep, made by the returned left matrix
Read the full text of it in UrSymmetry.nb. Test it on NUrep, constructed above and already proved non-unitary : NUrep Dimensions 88, 2, 2<
Map@UnitaryQ, NUrepD
8True, False, False, True, False, False, False, False<
We take the second part below, for the reason just above. Urep2 = MakeUnitary@N@NUrepDDP2T; % MatrixList Size@8D :
1. 0 , 0 1.
0 1. , -1. 0
0 -1. , 1. 0
0.313844 0.949474 , 0.949474 -0.313844 0.949474 -0.313844 , -0.313844 -0.949474
-1. 0 , 0 -1.
-0.313844 -0.949474 , -0.949474 0.313844
-0.949474 0.313844 > 0.313844 0.949474
Is it unitary now?
Map@UnitaryQ, Urep2D Union
8True<
The MakeUnitary operator can be really useful when making representations on the basis of physically meaningful basis functions, like orbitals. Instead of balancing the functions so that they give a unitary representation, just use them as they are, and then call MakeUnitary on the rep they produce. 394
MakeUnitary operator
The MakeUnitary operator can be really useful when making representations balancing the functions so that they give a unitary representation, just use them as they are, and then call MakeUnitary on the rep they produce. OnYour Own Take any unitary representation, tangle it up with a random similarity transform, and then make it unitary again with the MakeUnitary operator. Does this restore the original representation?
29.4 End Notes 29.4.1 A side effect In the interest of full disclosure, we must admit that MakeUnitary often does something you may not like. The CartRep of D3 is block diagonal CartRep@"D3"D; % MatrixList Size@7D 1 0 0 : 0 1 0 , 0 0 1
-
1
3
1
3
2
2
,
1
-
0
2
0
1
1
3
2
2
3
1
2
2
0
0
-
-
0
2
-
2
0
1 0 0 0 -1 0 , 0 0 -1
3
-
2
3
-
2
0 1 2
, 0 -1
-
,
1
0
2
0
-
0
0
1 3
-
3
1
2
2
0
0
2
0
>
0 -1
We make it non-unitary by similarity transforming it by a non-unitary sMat : sMat = 882, 3, 0<, 81, 2, 0<, 80, 0, 1<<; sInv = Inverse@sMatD; B = Map@sMat.ð.sInv &, CartRep@"D3"DD N; % MatrixList Size@7D
1. 0. 0. : 0. 1. 0. , 0. 0. 1.
6.4282 -11.2583 0. 4.33013 -7.4282 0. , 0. 0. 1.
7. -12. 0. 4. -7. 0. , 0. 0. -1.
-7.4282 11.2583 0. -4.33013 6.4282 0. , 0. 0. 1.
-0.0358984 1.66987 0. 0.598076 0.0358984 0. , 0. 0. -1.
-6.9641 10.3301 0. -4.59808 6.9641 0. > 0. 0. -1.
Rep B is block diagonal, but nonunitary: Map@UnitaryQ, BD
395
Symmetry Theory 8True, False, False, False, False, False<
Apply MakeUnitary , and look at the result: B U = MakeUnitary@BDP2T; Map@GridForm, %D Size@6D :
1. 0 0
0 1. 0
0 0 1.
-0.5 0 -0.866025
0 1. 0
0.998203 0 0.0599153
0 -1. 0
,
-0.5 0 0.866025 0.866025 0 -0.5
0 1. 0
-0.447214 0 -0.894427
,
0.0599153 0 -0.998203
-0.866025 0 -0.5
,
-0.55099 0 0.834512
,
0 -1. 0
-0.894427 0 0.447214
0 -1. 0
0.834512 0 0.55099
,
>
Is it unitary? Map@UnitaryQ, B UD
8True, True, True, True, True, True<
Yes, but the block diagonal form has been lost. The moral of this story is simple. If you need to analyze some wretched nonunitary representation, make it unitary first, then block diagonalize it.
396
30. Schur's reduction Preliminaries
30.1 Schur's idea In Chapter 28 (ReducibleReps) we introduced the concept of reducible and irreducible representations, and demonstrated concretely the important things you learn by reducing a representation to block diagonal form. However, we had to leave the block reduction method unexplained, because at that time we did not yet have the concept of the universal pseudo-commuter matrix. or that of the universal true commuter matrix. That was developed in Chapter 26 (TestForSimilarity), and in this chapter we will show how Shur may have used it to reduce a representation. We say “may have” because mathematicians are very good at covering their tracks, and no one knows exactly how he arrived at his famous lemmas. This is just one attempt to find the trail that led him to glory. Suppose all the matrices of a representation are reducible to the pattern Α 0 0 0 Β 0 0 0 Β
u 0 0 0 v w . Then it is easy to see that the diagonal matrix 0 x y
com-
mutes with all of them, multiplying the upper left block by Α and the lower right block by Β. In detail, u 0 0 0 v w 0 x y
.
Α 0 0 0 Β 0 0 0 Β
==
Α 0 0 0 Β 0 0 0 Β
.
u 0 0 0 v w 0 x y
==
Αu 0 0 0 Βv Βw 0 Βx Βy
True
or in more general symbols, for all Bi in the group Bi .D = D.Bi
(30.1)
where D is diagonal and the Bi are block diagonal. But of course, with a new, unfamiliar rep one does not know what the block diagonal form is, or if it even exists. Let the matrices Ti constitute such a tangled representation. We now know how to find a universal commuter for them, obeying Ti .C = C.Ti
(30.2)
The formula for C was given as Eq. 27.15
C = Úi T-1 i .Q . Ti
(27.15)
Strangely, Q can be “ almost” any matrix of the right size (except the unit discusW.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, 397 be better DOI 10.1007/b13137_30, © Springer Science+Business Media, LLC 2009
Symmetry Theory
Strangely, Q can be “ almost” any matrix of the right size (except the unit matrix, which leads to a trivial result). Click if you need to review that discussion. Also, the word “almost” above needs a little expansion, but it will be better to do it farther down. Now just fantasize a little, the way Schur did (or seems to have done). Suppose you had a matrix S that diagonalizes matrix C by a similarity transform. Then you could similarity transform the whole of Eq. 30.2 as IS.Ti .S-1 M.IS.C.S-1 M = IS.C.S-1 M.IS.Ti .S-1 M
If S transforms C into a diagonal matrix D according to D = IS.Ti .S-1 M.D = D.IS.Ti .S-1 M
S.C.S-1 ,
(30.3) then (30.4)
Comparing this to Eq. 30.1, we see that Bi = S.Ti .S-1
for every i
(30.5)
So S is the elusive matrix that transforms tangled matrices Ti into block diagonal matrices Bi . But how can you construct this fantastic matrix S? The diagonalization of matrices like C by means of a similarity transform was not unknown in the nineteenth century. However, it was a rather heroic undertaking, for all but the smallest matrices. Today, of course, finding the S that diagonalizes a numerical C is just a routine task, given the Eigensystem operator. So using this advantage to the full, let's work out a concrete example to make sure that it all goes smoothly.
30.2 Two experimental rep reductions 30.2.1 Pure real example To automate this process, we need to do two examples by hand, one with a pure real eigensystem and one with a complex eigensystem. Both cases occur in the point groups. Below we construct a reducible rep by transforming the CartRep for group D3 . The tangling operator is in the preliminaries; click to see it. It is unitary because it uses an Euler rotation matrix with randomly chosen angles, so every time you call it, it returns a different result. We show only two matrices: repD3 = TangleU33@CartRep@"D3"DD; %P84, 5
398
Experimental reductions
-0.749384 0.225501 -0.622554 : 0.225501 -0.797097 -0.560165 , -0.622554 -0.560165 0.546481
-0.0764828 -0.739458 -0.668844 -0.739458 -0.407917 0.535542 > -0.668844 0.535542 -0.5156
Use MorphTest and UnitaryQ to verify that repD3 is what we want: MorphTest@repD3, "D3"D Faithful, or Isomorphic
Map@UnitaryQ, repD3D
8True, True, True, True, True, True<
In the preliminaries there is also an operator that constructs the universal commuter of a rep (á la Eq. 25.13); you may click here to read it.. Its syntax is UniversalCommuter@R, QD where R is a representation and Q is that strange arbitrary matrix. So use it on representation repD3 : Q33 = 889, 4, 1<, 87, 9, 9<, 84, 5, 8<<; CD3 = UniversalCommuter@repD3, Q33 D; % MatrixForm Size@8D
68.6098 29.1006 28.1188 29.1006 44.3384 18.7396 28.1188 18.7396 43.0518
Verify that CD3 is a universal commuter:
Map@HCD3 .ð -ð.CD3 L &, repD3D Chop Union
8880, 0, 0<, 80, 0, 0<, 80, 0, 0<<<
We must find the similarity transform that diagonalizes CD3 . We find its Eigen system, noting that its eigenvalues come out in increasing order, so degenerate eigenvectors come out as neighbors. This helps with the block diagonality. 8eVals, eVecRows< = Eigensystem@CD3 D; eVals Size@7D eVecRows GridForm Size@7D
8106.111, 24.9445, 24.9445< 0.733465 0.622634 0.679727
0.488814 -0.761914 -0.52746
0.472323 -0.178366 -0.509664
Do the standard check that Eigensystem performed correctly : eVecCols = Transpose@eVecRowsD; DD3 = DiagonalMatrix@eValsD; HCD3 .eVecCols - eVecCols.DD3 L Chop
399
Symmetry Theory 880, 0, 0<, 80, 0, 0<, 80, 0, 0<<
Is the matrix eVecCols a unitary matrix? eVecCols = Transpose@eVecRowsD; eVecRows.eVecCols ChopInteger GridForm 1 0 0
0 1 0.916007
0 0.916007 1
Eigensystem does not necessarily orthogonalize degenerate eigenvectors. If you want them orthogonal (and usually you do) you have to Orthogonalize them : eVecRowsOrth = Orthogonalize@eVecRowsD; % GridForm Size@7D 0.733465 0.622634 0.272681
0.488814 -0.761914 0.42491
0.472323 -0.178366 -0.86319
eVecColsOrth = Transpose@eVecRowsOrthD; Now they have to be orthonormal:
eVecRowsOrth.eVecColsOrth ChopInteger GridForm 1 0 0
0 1 0
0 0 1
Does eVecRowsOrth diagonalize CD3 ? eVecRowsOrth.CD3 .eVecColsOrth; % ChopInteger MatrixForm 106.111 0 0 0 24.9445 0 0 0 24.9445
So eVecRowsOrth is the fantastic matrix S that Schur imagined. Does it really block-diagonalize the whole rep? repD3Block =
Map@eVecRowsOrth.ð.eVecColsOrth &, repD3D ChopInteger; % GridList Size@7D
400
Experimental reductions
:
1 0 0
0 1 0
1 0 0
0 -0.5 0.866025
-1 0 0
0 0 1
1 0 0
,
0 -0.5 -0.866025
0 -0.866025 -0.5
0 0.712852 0.701314
,
0 0.701314 -0.712852
,
0 0.866025 -0.5 -1 0 0
,
0 -0.963782 0.266691
-1 0 0
0 0.25093 -0.968005
0 0.266691 0.963782 0 -0.968005 -0.25093
,
>
It does. Schur was right. On your own 1. Use MorphTest to check that all is well. 2. Add up the characters of the two blocks and compare with the characters in the BoxedCharacterTable for D3 . In some examples the 2 ´2 block is in the upper left; in others, the lower right. What determines this in general? (Think first)
30.2.2 Complex example Some representations produce a complex Eigensystem, which puts a little different twist on things. If the functions f + ä g and f - ä g support conjugate complex one-dimensional reps, then {f,g} ought to support a twodimensional real rep that will be reducible to two complex 1-D reps. We find such a situation in reps Eu,a and Eu,b of group Th . BoxedCharacterTable@"Th", 7D Th
Ag
1
4
4
3
1
4
4
S65 Σh
E C3 C32 C2 inv
S6
1
1
1
1
1
1
1
1
Ega 1
Ε
Ε*
1
1
Ε
Ε*
1
Egb 1
Ε*
Ε
1
1
Ε*
Ε
1
0
-1
3
0
0
-1
Tg
3
0
Au
¬ Class populations Note : Ε = Exp@- 2 Π ä 3D
3
9I x2 + y2 + z2 M=
Basis functions
9I x2 + 9I x2 +
3 -ä x2 + y2 + 3
ä x2 + y2 +
xy : yz , xz 8H x y z L<
1
1
1
1
-1
-1
-1
-1
Eua 1
Ε
Ε*
1
-1
-Ε
-Ε* -1 9I x3 y z +
Ε*
Ε
1
-1
-Ε*
-Ε
-1 9I x3 y z +
3 -ä x3 y z + x y3 z +
Eub 1
3
0
0
-1
-3
0
0
Tu
3
1
ä y2 - 2 z2 M=
3 -ä y2 - 2 z2 M= Ix Iy > Iz 3
ä x3 y z + x y3 z + x : y > z
ä x y3 z - 2 x y z3 M=
3 -ä x y3 z - 2 x y z3 M= 3
401
Symmetry Theory
basesThEu = TabulatedBases@"Th"DP86, 7
3 Ix2 - y2 M - 2 z2 N>>>,
3 Ix2 - y2 M - 2 z2 N>>>>
fnEua = basesThEuP1, 2, 1, 1T x y z Jx2 + y2 - ä
3 Ix2 - y2 M - 2 z2 N
fFn = fnEua . -ä ® 0 x y z Ix2 + y2 - 2 z2 M
gFn =
HfnEua - fFnL -ä
Collect@ð, zD &
3 x y Ix2 - y2 M z
repTh = MakeRepPoly@ 8fFn, gFn<, "Th"D; Short@% GridListD Size@7D :
1 0
0 1
, -
1
3
2
2
3 2
-
, 20,
1
-1 0
0 -1
,
-1 0
0 -1
>
2
Some are diagonal, some are not. We want them all diagonal, so start by making a universal commuter Q22 = 885, 7<, 82, 11<<; CTh = UniversalCommuter@repTh, Q22 D Simplify 88192, 60<, 8-60, 192<<
Check that it commutes:
Map@Hð.CTh == CTh .ðL &, repThD Union
8True<
We find the Eigensystem of CTh :
8eVals, eVecRows< = Eigensystem@CTh D Chop; eVals Size@8D eVecRows MatrixForm Size@8D
8192 + 60 ä, 192 - 60 ä< -ä 1 ä 1
402
Experimental reductions
Both eigenvectors and eigenvalues are complex. Make the standard check : UTh = Transpose@eVecRowsD; DTh = DiagonalMatrix@eValsD; HCTh .UTh - UTh .DTh L Chop 880, 0<, 80, 0<<
Check that UTh and its adjoint are orthonormal :
UÖTh = Conjugate@Transpose@UTh DD;
UTh .UÖTh ChopInteger FullSimplify 882, 0<, 80, 2<<
They are orthogonal, but not normalized. We could just divide them by 2 , but it is more general to call Orthogonalize on them. (Click here for details of this operator.) By default, it uses Dot to take scalar products, so it does not do the right job on complex vectors. This is easily fixed. We prepare a scalar product function CxDot for use with complex vectors. It conjugates the right factor before using Dot : Clear@CxDotD; CxDot@a_, b_D := Dot@a, Conjugate@bDD GramSchmidt is a bit of overkill in this case, but here it is : eVecRowsOrth = VTh = Orthogonalize@eVecRows, CxDotD ::-
ä
1 ,
2
>, :
2
ä
1 ,
2
>>
2
VÖTh = Transpose@Conjugate@VTh DD; VTh .VÖTh
881, 0<, 80, 1<<
Now the eigenvectors are orthonormal in the complex sense. Do they diagonalize the universal commuter? VTh .CTh .VÖTh ChopInteger MatrixForm K
192 - 60 ä 0 O 0 192 + 60 ä
Yes. So let them block-diagonalize the whole rep : repThBlock =
MapAVTh .ð.VÖTh &, repThE Simplify ExpandAll;
Short@% GridList, 3D Size@7D
403
Symmetry Theory
:
1 0
0 1
,
1 2
-
ä
3
, -
0
18,
-1 0
-
0
2
0 -1
,
-1 0
1 2
+
ä
1
ä
-
2
3
3
0
2
, -
0
2
0 -1
,
-1 0
ΕRules = SmartRulesB-
1
-
ä
ä
3 2
3
2
+
ä
3 2
>
0 -1
Display repThBlock with the number - 12 -
1
symbolized as Ε :
, ΕF;
HrepThBlock . ΕRulesL MatrixList Size@7D 2
:
1 0 , 0 1 Ε* 0 , 0 Ε -Ε 0 0 -Ε*
Ε 0 , 0 Ε*
Ε 0 , 0 Ε*
Ε* 0 , 0 Ε ,
-Ε* 0 , 0 -Ε
-Ε 0 0 -Ε*
Ε* 0 , 0 Ε ,
-Ε* 0 , 0 -Ε
2
Ε 0 , 0 Ε*
Ε 0 , 0 Ε*
1 0 , 0 1
1 0 , 0 1
-Ε 0 0 -Ε*
,
-Ε* 0 , 0 -Ε
-Ε 0 0 -Ε*
Ε* 0 , 0 Ε 1 0 , 0 1
,
-1 0 , 0 -1
-1 0 , 0 -1
-Ε* 0 , 0 -Ε -1 0 , 0 -1
-1 0 > 0 -1
Yes; they are all made of two 1 ´1 blocks. If you have not seen SmartRules before, here is its thumbnail description: SmartRules[cmplxExpr, s] returns eight rules. The first turns cmplexExpr into symbol s. The other seven recognize variations of cmplxExpr, returning -s, s* , -s* , ä s, -ä s, HäsL* , or H-äsL* , as appropriate.
30.3 The ReduceRep operator We are now ready to define an operator that will block diagonalize any representation. Drawing together the steps in the real and complex examples, Clear@ReduceRepD; ReduceRep@rep_D := Module@8a, b, c, U<, H*Body*L 8a, b, c< = Dimensions@repD; If@b =!= c, Return@"rep is not square"D, Null, NullD; U = IdentityMatrix@bD; ReduceRep@rep, UDD;
404
Operator ReduceRep
ReduceRep@rep_, Qmat_D := Module@8Cmat, esysC, VrowsRaw, CxDot, a, b, Vrows, Vcols<, H*Body*L Cmat = Simplify@Expand@UniversalCommuter@rep, QmatDDD; esysC = Eigensystem@CmatD; VrowsRaw = esysCP2T; CxDot@a_, b_D := a.Conjugate@bD; Vrows = Chop@Orthogonalize@VrowsRaw, CxDot, Method ® "GramSchmidt"DD; Vcols = Conjugate@Transpose@VrowsDD; Chop@ExpandAll@ Simplify@HVrows.ð1.Vcols &L repDDDD Remember that you have already seen an application of this, back in Chapter 28 (ReducibleReps). This is the secret construction method we used there.
30.4 Tests of ReduceRep 30.4.1 Basic tests of ReduceRep Make sure it works on repD3 and repTh, the examples we did by hand. We do them again, using the same Q matrices as before. H*Real example*L repD3Block - ReduceRep@repD3, Q33 D Chop Union 8880, 0, 0<, 80, 0, 0<, 80, 0, 0<<<
H*Complex example*L HrepThBlock - ReduceRep@repTh, Q22 DL Chop Union 8880, 0<, 80, 0<<<
30.4.2 Benzene orbitals again, by ReduceRep As a little tougher test, we let ReduceRep do the pz rep of D6 h , which supports the Π orbitals of benzene.
405
Symmetry Theory
8pzRepD6h, bzRules< = MakeRepAtomic@"benzene", "D6h", atomKind ® "C", preFactor ® zD; Dimensions@pzRepD6hD 824, 6, 6<
Q 66 = 88-6, -2, -5, 2, 6, -6<, 8-5, -3, 3, -6, -9, 2<, 83, 2, 5, -3, -1, -9<, 85, -3, -10, 6, 7, 0<, 88, 5, -1, 3, 9, 6<, 86, -5, -1, 2, -3, 0<<; Use ReduceRep on it, displaying only the first 3 elements : pzRepReduced = ReduceRep@pzRepD6h, Q 66D; Take@pzRepReduced, 3D GridList Size@6D -1 0 :
1 0 0 0 0 0
0 1 0 0 0 0
0 0 1 0 0 0
0 0 0 1 0 0
0 0 0 0 1 0
0 0 0 0 0 1
0
1 2
0 -
3
-
0
0
3
1 2
0
0
0
0
0
0
0
2
0
0
0
0
0
0
0
0
0
0
0
0
0 ,
-
0
0
0 0
-
1 2 3
2
0
1
2
0
0
0
2 3
0
0
0
0
-
1
3
2
2
3 2
0
-
1
0
0
2
0
1
2
2
0
3
,
0 0
0
1 2
0
-1
0
0
0
3
-
>
0
2
-
1
0
2
0
1
The block sizes are 1 Å 2 Å 2 Å 1. The logical next step, already carried out earlier, is to find the characters of the blocks and use the characters to identify the names of the irreducible representations. A better and quicker method lies ahead in Chapter 34 (Rep Reduction), but it depends on the Great Orthogonality, which we are still developing. Be patient.
406
Overview
30.5 What have we learned?
30.5.1 A whiff of Schur's First Lemma In the last chapter we asked the pseudo-commuter algorithm to do the impossible; namely, to find the similarity transform matrix for two reps that were not related by a symmetry transform. It responded surprisingly but reasonably, returning a trivial but formally correct result, an all-zero matrix. Now let's set the computer on another impossible task, just to see what we get. What happens if we try to reduce an irreducible rep? The character table of group Td says that 8x, y, z< is the basis of irreducible rep T2 ; that means the CartRep of Td is irreducible. We pull it up : repTd = CartRep@"Td"D; Map@MatrixForm, repTdD Size@5D 1 0 0 : 0 1 0 , 0 0 1
0 0 -1 , -1 0 0 0 1 0
0 -1 0 0 0 1 , -1 0 0
0 -1 0 0 0 -1 , 1 0 0
0 0 1 -1 0 0 , 0 -1 0
0 0 -1 , 1 0 0 0 -1 0
0 1 0 0 0 -1 , -1 0 0
0 1 0 0 0 1 , 1 0 0
0 0 1 1 0 0 , 0 1 0
-1 0 0 0 -1 0 , 0 0 1
1 0 0 , 0 -1 0 0 0 -1
-1 0 0 , 0 1 0 0 0 -1
0 1 0 , -1 0 0 0 0 -1
0 -1 0 , 1 0 0 0 0 -1
-1 0 0 0 0 1 , 0 -1 0
-1 0 0 0 0 -1 , 0 1 0
0 0 1 0 -1 0 , -1 0 0
0 0 -1 , 0 -1 0 1 0 0
0 0 1 0 1 0 , 1 0 0
0 1 0 1 0 0 , 0 0 1
1 0 0 0 0 1 , 0 1 0
0 0 -1 , 0 1 0 -1 0 0
0 -1 0 -1 0 0 , 0 0 1
1 0 0 0 0 -1 > 0 -1 0
There; it is nice and simple and guaranteed irreducible. So let's try to reduce it. The first step is to make the universal commuter, for which we have the command already written : CTd = UniversalCommuter@repTd, Q33 D MatrixForm Size@7D
208 0 0 0 208 0 0 0 208
The next step is to diagonalize CTd , and then … But wait! It is already diagonal! Not only that, it is a constant matrix (a number times the unit matrix). Constant matrices commute with all matrices, so this is indeed a correct, but trivial, universal commuter. We remark again that the universal commuter algorithm is very hardy. Even when asked for the impossible, it returns something that is formally correct.
407
Symmetry Theory
On your own Run that UniversalCommuter command several times. Remember, it uses a random matrix, so every time you run it the answer is different. You will see different values of the constant, but it is always a constant matrix. Try it.
30.5.2 Generalizing from examples Examples can help one to sniff out a theorem, but unless you can prove that your examples exhaust all possibilities, they do not constitute a proof. The real work is in figuring out why the regularities seen in the examples work as they do, and in creating a statement that encapsulates exactly what is seen in all the examples, including the “failures”. For instance, here is a bad initial attempt to state a theorem consistent with the observations above. “If rep A has a constant universal commuter matrix, then A is irreducible.” This is consistent with what you will see nearly all the time if you choose the arbitrary Q matrix of the algorithm by a random process, to an accuracy of fourteen or sixteen digits. But it will not do as a theorem statement, because there might be certain special Q matrices that produce a constant universal commuter, even in reducible cases. We need a way to state it so that this possible exception does not ruin it. In the next chapter you will see how Schur did this, in his famous theorem known today as Schur's First Lemma. Click into the End notes to see an actual example of a Q matrix (originally randomly chosen) which shows quite peculiar behavior. On your own Try to formulate a proper statement of Schur's First Lemma before you see how Schur did it. Don't be dreamy about it; actually write it out.
408
End Notes
30.6 End notes 30.6.1 Characters of the blocks If you do not RoundSort the eigensystem, the arbitrary matrix Q used in MakeUnitary determines the order of the blocks. If it is generated randomly on each call, the order of the blocks may change. The 2 ´2 block is either upper left or lower right, so one of the following diagrams will be correct: 0 0 0 0
0 0 0 0
But if the eigensystem is Transposed and RoundSorted, then the {{eval,evec}} pairs come out with evals in ascending order. Then if Transposed again to make {{evals},{evecs}} the evecs will appear in the order of their evals, and this determines the order of the blocks. So the upper left block has the lowest eval, etc.
30.6.2 Orthogonalization Orthogonalize is a core operator in Version 6. It can use any of several algorithms, but by default it uses the Gram-Schmidt procedure. For a clear, detailed explanation of how it works, click here to go to Eric Weisstein's MathWorld encyclopedia article on it.
30.6.3 Don't trust those Q matrices The RepReduce algorithm is not perfect. Here we redo the benzene orbital reduction using a Q66 matrix that causes a block diagonal transform with three twofold degeneracies. This is not totally wrong, but it is incomplete. One of the twofold degeneracies could have been reduced further to two 1 ´1 blocks. The problem appears when you use the following Q matrix : Q 66BAD = 884, 5, -3, -9, 2, 6<, 8-5, 2, 8, 1, -3, 7<, 8-10, 6, 2, 10, -8, 2<, 8-10, -7, -1, 7, 1, 4<, 87, 9, -7, 10, 4, -6<, 8-10, -5, -7, -2, -6, 6<<;
409
Symmetry Theory
pzRepReduced = ReduceRep@pzRepD6h, Q 66BADD; Take@pzRepReduced, 3D MatrixList Size@6D
1 0 0 : 0 0 0
0 1 0 0 0 0
0 0 1 0 0 0
0 0 0 1 0 0
0 0 0 0 1 0
0 0 0 , 0 0 1
1
3
2
2
-
3
1
2
2
0 0 0 0
0 0 0 0
0
0
1
0 0
-
2
0 0 0
0
0 0
1
3
2
2 3 2
-
1
0 0 0 0
,
0 0
3
1
2
2
3
0
0
0 -
2
2
0 1 1 0
0 0
0 0
0 1
3
0
2
0 0
0
2
0 0
0 0
0 0 3
0 0
0 0
>
2 1
0 0
2
0 1 1 0
Interactive readers can look at them all. They all consistent with three blocks of size 2 ´2. MorphTest says the rep is faithful, and it passes the unitary test. Very seldom does a randomly chosen Q matrix give such a result, but it did happen once and we have preserved it as a curiosity. Below we try to find the root of this behavior: C = UniversalCommuter@pzRepD6h, Q 66BADD Simplify; % MatrixForm Size@6D
100 36 -42 -72 -42 36
36 100 36 -42 -72 -42
-42 36 100 36 -42 -72
-72 -42 36 100 36 -42
-42 -72 -42 36 100 36
36 -42 -72 -42 36 100
Matrix C passes the universal commuter test. But there is something strange about its eigenvalues : 8eVals, eVecRows< = Eigensystem@CD; eVals 8250, 250, 34, 34, 16, 16<
There is an extra degeneracy, caused by something about Q66BAD. Follow it out step-by-step if you like; this is the only strange feature that appears. The eigenvalues are indeed a function of the Q matrix, so we seem to have hit on one that just happens to induce an extra degeneracy. It does not seem very profound. A cleverly chosen Q matrix plays an essential role in Schur's Lemmas, but you can't trust random examples in the reduction algorithm. The rep reduction method that everyone uses lies ahead in Chapter 35 (RepAnalysis). It does not involve any arbitrary Q matrix, and is utterly reliable.
410
31. Schur's First Lemma Preliminaries
31.1 Statement of the Lemma We read Schur's First Lemma remembering that a constant matrix (a number times a unit matrix) commutes with all matrices. Schur's First Lemma 1. If a rep has a non-constant universal commuter, it is reducible. 2. If a rep is irreducible, its only universal commuters are constant matrices. Note that the two parts of this lemma are not simple alternatives "assume X" and then "assume not-X". Let X be the statement “ The rep has a non-constant universal commuter", and let Y be the statement "The rep is reducible". The first part is 1. If X, then Y. The second part has the form 2. If not-Y, then not-X. These statements are mutually contrapositive, and Boolean logic says that if a statement is True, then its contrapositive is automatically True also.
31.2 Proof 31.2.1 Introduction to the proof We begin with any general representation A. Schur's reduction algorithm shows us how to compute a universal commuter C that obeys Ai . C == C. Ai
(31.1)
for all i in the group. It is then always possible to find (by eigensystem techniques) a similarity transform that diagonalizes C, converting Eq. 31.1 into a form like Bi .D = D.Bi where D is
and Bi
block
(31.2) are the transforms of the 411
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_31, © Springer Science+Business Media, LLC 2009
Symmetry Theory
where D is diagonal and Bi (possibly block diagonal) are the transforms of the Ai . To be concrete we take a 4´4 example : ì ì ì ì
ì ì ì ì
ì ì ì ì
a 0 ì 0 b ì . ì 0 0 ì 0 0
0 0 c 0
0 0 0 d
==
a 0 0 0
0 b 0 0
0 0 c 0
0 ì ì 0 ì ì . ì ì 0 ì ì d
ì ì ì ì
ì ì ì ì
(31.3)
where the numbers {a,b,c,d} are the eigenvalues of matrix C. The Bi matrices are pure diamonds, each diamond ì generally standing for a different number.
31.2.2 Part I: Assume a non-constant universal commuter To have the minimal case of a non-constant commuter, let all the eigenvalues have value a except the last, which has a different value b. Then Eq. 31.3 multiplies out to give aì aì aì aì
aì aì aì aì
aì aì aì aì
bì bì bì bì
aì aì aì bì
==
aì aì aì bì
aì aì aì bì
aì aì aì bì
(31.4)
Subtracting the right side from both sides, we get 0 0 0 -Ha - bL ì 0 0 0 -Ha - bL ì 0 0 0 -Ha - bL ì Ha - bL ì Ha - bL ì Ha - bL ì 0
==
0 0 0 0
0 0 0 0
0 0 0 0
0 0 0 0
(31.5)
Since (a-b) is nonzero by assumption, the values of the ì that multiply (a-b) are now known: they must be zero. So every matrix of the representation must have the pattern Ai
=
ì ì ì 0
ì ì ì 0
ì ì ì 0
0 0 0 ì
(31.6)
Therefore, if even one eigenvalue is different from the others (making the diagonalized commuter non-constant), then the rep is reducible, which was to be shown. A corollary Above, we assumed the eigenvalues were {a,a,a,b} and we found blocks of size 3 ´3 and 1 ´1. By a similar argument, if the eigenvalues are {a,a,b,b} then all the rep matrices have two blocks of size 2 ´2 : 412
Ai
=
ì ì 0 0
ì ì 0 0
0 0 ì ì
0 0 ì ì
(31.7)
Proof of the Lemma
Ai
=
ì ì 0 0
ì ì 0 0
0 0 ì ì
0 0 ì ì
Do the row-by-column multiplications on paper, and you will soon see that every set of N equal eigenvalues yields a diagonal block of size N ´ N. The automatic sort done by Eigensystem insures that the equal eigenvalues are listed together, forming the square blocks that we desire. On your own Carry out the similar argument explicitly. Also, look at a case where equal eigenvalues are scattered around, instead of being listed all together.
31.2.3 Part II: Assume the rep is irreducible Once a statement has been proved true, its contrapositive does not really need a separate proof. But this may seem like skating on thin ice, so we prove it anyway. It is short and sweet: Eq. 31.5 was 0 0 0 -Ha - bL ì 0 0 0 -Ha - bL ì 0 0 0 -Ha - bL ì Ha - bL ì Ha - bL ì Ha - bL ì 0
==
0 0 0 0
0 0 0 0
0 0 0 0
0 0 0 0
This time assume that the rep is not reducible, and the values of a and b are unknown. Then the ì symbols are not all zero in all the rep matrices, because under this hypothesis there does not exist any transform that could change them all into zeroes. (This is the meaning of irreducible.) This means that in at least one element of one rep matrix we have Ha - bL ì = 0, where the ì is not zero. From this, we must conclude that a = b, so that in the diagonalized universal commuter all the elements are equal. So the only universal commuter of an irreducible rep is a constant matrix, which was to be shown. Now we have direct proofs of both parts of Schur's First Lemma.
413 (31.7)
Symmetry Theory
31.3 End Notes
31.3.1 Converse and Contrapositive, in English In the statements below, we accept that nothing but water today will save the garden. But we do not accept that diamond is the only stone that scratches glass. Statement: 1. "If the garden gets water today, it will live." (Water today) Þ (Garden lives) 2. "If this is a diamond, it will scratch glass" (Diamond) Þ(Scratch) The converse of a true statement may be true or false. Converse: (swap the premises) 1. "If the garden lives, it (will have had water) today." (Garden lives) Þ (Water today) 2. "If this stone scratches glass, it is a diamond." (Scratch) Þ (Diamond)
True True
True False
The contrapositive of a true statement is always true. Contrapositive: (swap the premises and negate both) 1. "If the garden (dies), it (will not have had water) today." Not[Garden lives] Þ Not[Water today] True 2. "If this will not scratch glass, it is not diamond." Not[Scratch] Þ Not[Diamond] True
414
32. Schur's Second Lemma Preliminaries
32.1 Introduction Schur's First and Second Lemmas are lemmas for the Great Orthogonality. They are generalized statements about the results of two closely related algorithms; the First generalizes results seen using ReduceRep, presented in Chapter 30 (SchursReduction); the Second generalizes a result seen in Chapter 26 (TestForSimilarity).
32.2 Statement and discussion 32.2.1 Statement
Schur's Second Lemma If a group has representations A and B that are irreducible and not similar, then the equations Ai .P = P.Bi , for all i in the group, have only the trivial solution P = 0.
32.2.2 Comment This lemma is a statement about the way the similarity algorithm fails when there is no similarity transform that links two representations A and B . The algorithm finds P in the equation Ai .P = P.Bi and you might think that failure would be a matrix P that has no inverse, so that it cannot be used in the transform equation Ai = P.Bi .P-1 . But Schur's Second Lemma says that failure has to be much more drastic than this. When no similarity transform exists, the only possible P is one that is all zeroes. These zeroes are central to the structure of representation theory. The next chapter will show them to be the orthogonality zeroes of the Great Orthogonality. W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_32, © Springer Science+Business Media, LLC 2009
415
Symmetry Theory
These zeroes are central to the structure of representation theory. The next Orthogonality.
32.3 Proof, using the unitary property 32.3.1 An equation to which Schur's First Lemma applies We start with the definition of the pseudocommuter, and make a few simple maneuvers Ai .P = P . Bi
HAi .PLÖ = HP . Bi LÖ
(32.1)
PÖ .AÖi = BÖi .PÖ If both A and B are unitary, we can replace the dagger by an inverse: -1 Ö PÖ .A-1 i = Bi .P
(32.2)
or multiplying from the left by P ,
-1 Ö IP .PÖ M .A-1 i = P .Bi .P
(32.3)
Don't set IP .PÖ M to 1 just yet. It could be 1, but it does not have to be, as you will see. If element k is inverse to element i, this is IP .PÖ M .Ak = P .Bk .PÖ
(32.4)
But in the first line of this proof we assumed that P .Bk was the same as Ak .P so making this replacement on the right, we have IP .PÖ M .Ak = Ak .IP.PÖ M
(32.5)
Look at this with squinty eyes. It says that P .PÖ is a universal commuter for rep A. But A was assumed irreducible, and Schur's First Lemma says any universal commuter for an irreducible rep must be a constant matrix; i. e., P .PÖ = c U
(32.6)
where c is a number and U is the unit matrix. To proceed farther, we must divide our thinking into two cases. So far, reps A and B might have been either the same size or different sizes, and P either square or rectangular. In either case, of course, P .PÖ is square and the same size as A. But now we need to do something that is possible only with square matrices, so we specialize to the Square Case and the Rectangular Case.
416
32.3.2 Square Case
Proof of the Lemma
32.3.2 Square Case Taking the determinant of both sides of Eq. 32.6, we have DetAP .PÖ E = Det@c ID = cdimB
(32.7)
where dimB is the dimension of rep B. But if P is square DetAP .PÖ E = Det@PD DetAPÖ E
(32.8)
Now the c's down the diagonal of P .PÖ must be either zero or nonzero. If nonzero, the inverse of P exists and we can write from our original assumption that Ai = P . Bi .P-1
(32.9)
This says that A and B are similar. But by hypothesis A and B are not similar, so it must be true that c = 0, since this is the only thing that can prevent the conclusion that they are similar. Therefore P .PÖ = c I = 0
(32.10)
We cannot conclude from this that P is a zero matrix, because it is easy to find two nonzero matrices that multiply to give a zero matrix. However, look at the subscripted form of the last equation. It is Úk Pi,k PÖk,m = 0
(32.11)
and by the definition of the dagger
Úk Pi,k P*m,k = 0
(32.12)
The case i = m tells us everything we want to know:
Úk Pi,k P*i,k = Úk Pi,k ¤2 = 0
(32.13)
The summands are absolute squares and cannot be negative, so if the sum is zero, the summands must all be zero individually. Thus i,k
Pi,k º 0
(32.14)
This is the end of the square case. We conclude that if A and B are of the same size, and irreducible, and not similar, then AR .P = P . BR can be true for all R in the group only if P is composed entirely of zeroes.
417
Symmetry Theory
32.3.3 Rectangular case This case is now very easy. Take the equation with rectangular P and pad the smaller rep with rows and columns of zeroes until it is the same size as the larger rep. Now pad P appropriately, and you have, for example, Ai . P = P . Bi 0 0 0 . 0 = 0 . 0 0 0 0 0 0
(32.15)
This is now the square case, and by the reasoning above, the padded P must be all zeroes. But the rectangular P is just a subset of the square padded P , so it is all zeroes too.
32.3.4 Coda The two cases are obviously exhaustive (square or not square), so the theorem is proved.
32.4 A whiff of the great orthogonality If the arbitrary matrix Q is the unit matrix, the corresponding pseudocommuter is the special case ÚR A-1 R . BR . This is a nice simple formula for investigating the cancellations that give those all-zero matrices. Let's carry this sum out without an automated Dot operator, just as Schur might have done by hand. Group D6 will make a good choice because it has two 2-D irreducible reps : BoxedCharacterTable@"D6"D
418
Toward the Great Orthogonality
D6 1
2
2
1
3
A1 1
1
1
A2 1
1
1
1
1
1
-1
B2 1 -1
1
-1 -1
-1 -2
1
E2 2 -1 -1
9I x2 + y2 M, I z2 M= Basis functions 8H z L, H Iz L<
1
-1 -1
1
B1 1 -1
E1 2
¬ Class populations
3
C¢2 C¢¢ 2
E C6 C3 C2
2
9I x3 - 3 x y2 M=
-1
1
1
0
0
0
0
9I -3 x2 y + y3 M=
x xz :K O, K O, y yz :
x2 2
-
Ix > Iy
>
y2 2
xy
We take A to be rep E1 of group D6 , and we take B to be rep E2 . They are easy to construct, and we simultaneously make the inverse rep for A : A = MakeRepPoly@8x, y<, "D6"D; A-1 = Map@Inverse, AD; % GridList Size@6D
:
1 0
0 1
,
1
3
2
2
-
-
1
3
-
2
1
1
3
1
2
2
2
2
, -
-1 0
,
0 -1
1 0
,
3 2
,
1
3
2
2
3
1
3
2
2
2
-
1
3
2
2
3 2
3
2
2
3
1
2
2
,
1
0 1
3
-
2
3
-
2
,
2
,
1
-1 0
,
,
1
-
1
-
0 -1
2
-
2
-
2
3
1
-
2
3
-
2
3
-
2
1
,
-
2
>
2 1 2
B = MakeRepPolyA9x2 - y2 , x y=, "D6"E; % GridList Size@6D
:
1 0
-
0 1
,
1
-
3
-
1 2
3
-
-
4 1
, -
2
1
3
2
4 1
-
3
, -
2
3
-
4 1
3
2
4 1 2
,
1 0
0 1
,
1 0
0 -1
, -
2
1
3
3
-
2
,
1
3
2
4 1
3
2
,
1 0
0 -1
1
3
2
4 1
-
3
1
-
2
3
,
2
3 4 1
,
2
, -
1 2
3
-
3 4 1
>
2
The Second Lemma says we should get all zeroes if we sum over both R and k :
419
Symmetry Theory
TableBâ â A-1 PR, m, kT BPR, k, iT, 8i, 2<, 8m, 2
2
R=1 k=1
880, 0<, 80, 0<<
and we do. But just out of curiosity, let us delay the sum over k so that we can see the two matrices that add together to give the zero matrix. For the summand with k = 1 : k = 1; TableBâ A-1 PR, m, kT BPR, k, iT, 8i, 2<, 8m, 2
R=1
880, 0<, 80, 0<<
For the summand with k = 2 : k = 2; TableBâ A-1 Pr, m, kT BPr, k, iT, 8i, 2<, 8m, 2
r=1
880, 0<, 80, 0<<
Clear@kD Very surprising! The sum over k has nothing to do with the vanishing. If you sum over the group first, the matrices that you later add together are already pure zeroes. If you see something like this once, you will probably say it is a coincidence. You were looking for a nontrivial sum like K
a 0 -a 0 O+K O 0 b 0 -b
880, 0<, 80, 0<<
but maybe you were cheated out of it by the simplicity of group D3 . On your own Do more examples, looking for those elusive nonzero matrices that add together to give all zeroes. The 3-D reps T1 and T2 of Td would be good. Finally, you may begin to sense the dim outlines of a Great Orthogonality, and give up this fruitless search.
420
33. The Great Orthogonality Preliminaries
33.1 Skewers We define a new term which helps greatly in stating and in understanding the Great Orthogonality. Consider the irreducible representations of some group. In the figure below, we take the octahedral group O, with reps named A1 , A2 , E, T1 , and T2 . Each representation is a List of h matrices, where h is the group order. In each rep, think of the h matrices as stacked up like a deck of cards. (For the octahedral group, h is 24, but we show only the first 6 below.) For the two T reps the matrices are 3 ´3; for E, 2 ´2, for the two A reps, 1 ´1. Now thrust a skewer through the deck at the i,j position, making a shishkebab of all the i,j elements in the stack of matrices. This list we call the "skewer of the matrix list at the i,j position".
T1
T2
E
A2
A1
Fig.33.1 For visual clarity, we show only the first six matrices and only the diagonal skewers. But a skewer goes through every element position of every matrix. The octahedral group O has 24 skewers (count 'em), each one being a 24D vector.
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_33, © Springer Science+Business Media, LLC 2009
421
Symmetry Theory
The skewer is therefore just a vector (sometimes complex), and the number of elements in a skewer vector is equal to the order of the group. In other words, if there are h elements in the group, the skewers are vectors in an h-dimensional space.
33.2 Two statements of the Great Orthogonality 33.2.1 In skewer language
The Great Orthogonality 1. All the skewers of all the irreducible representations of a group are orthogonal. 2. The scalar product of each skewer with itself is h/d, where h is the order of the group and d is the dimension of the skewer's representation. 1. The phrase “ all the irreducible representations of a group” must be clarified. There are infinitely many similarity transforms of any representation, and obviously we not counting them separately. Perhaps the word “ nonsimilar” or “ inequivalent” should be inserted somewhere in the statement, but usually it is left unsaid. 2. If the skewers are complex, orthogonality is understood in the complex sense, u.Hv* L = 0. 3. Orthogonality of skewers holds both within irreducible representations and between different irreducible representations. Important comment The Great Orthogonality sets a limit on the number of irreducible representations that can exist. In an h dimensional space, it is impossible to have more than h linearly independent orthogonal vectors (or skewers). This limits the number of independent representations that can exist. We turn this into a quantitative statement : All representations are square , so if species number s is of size ds ´ ds the number of skewers it possesses is d2s . But because of their orthogonality in an h-dimensional space, the total number of such skewers cannot be more than h. Therefore we have the inequality
422
Two statements
â d2s £ h Ns
s=1
where the sum limit Ns is the number of species. Previously, one might have thought that Ns might be very large, or infinite, and that our failure to find more than a few irreducible reps merely meant that the missing ones were very complicated or very large. But now, this thought is forbidden. Later, we will show that the equality actually does hold in all cases.
33.2.2 In detailed subscript language Here is a more traditional statement of the Great Orthogonality : Let every element of every irreducible representation be symbolized by a G with four indices. There cannot be less that four, because we must specify which deck of cards (a lower case label i for irreducible representation), which card in the deck (an upper case Greek label (like L )for element number), and which position on the card (two lower case Greek indices like Α,Β). So each individual matrix element in the complete set of irreducible representations has its own HiL
GΜ,Ν @LD.
We could also attach a capital Script index G to indicate the group,
but there is not any room left, so we suppress it.
To state the Great Orthogonality we need only these G symbols, plus h (the order of the group, and d[i], the dimension of each representation. The statement is fairly compact : The Great Orthogonality h
HiL Μ,Ν @LD
SG L=1
HjL
K GΑ,Β @LDO
*
=
h ∆ ∆ ∆ d@iD i,j Μ,Α Ν,Β
(33.1)
The ∆ symbols are Kronecker deltas; 0 when the subscripts are not equal and 1 when they are. In other words, they are unit matrices. This is not an abstraction. It is real. Set nKD to any dimension you like : nKD = 3; Table@∆i,j , 8i, nKD<, 8j, nKD
The Great Orthogonality will not be hard to prove now that we have Schur's Lemmas. But first, to make friends with this monster, we do two numerical examples. 423
Symmetry Theory
Lemmas. But first, to make friends with this monster, we do two numerical examples.
33.3 Two Great Orthogonality demos 33.3.1 With all reps one-dimensional First we do an example that has only 1-D reps, for simplicity. But we choose one that has complex character vectors : grp = "C6"; BoxedCharacterTable@grpD C6
1
1
A
E 1
C6 1
B
1
-1
1
1
1
¬ Class populations Note : Ε = Exp@- 2 Π ä 3D
1
C62 C63 C64 C65 Basis functions 1 1 1 1 8H z L, H x2 + y2 L, H z2 L, H Iz L< 1 *
-1
1
9I Hx ±ä yL3 M=
-1
8H x - ä y L<
*
E1a
1 -Ε
Ε
-1
Ε
E1b
1 -Ε*
Ε
-1
Ε* -Ε
E2a
1
Ε*
Ε
1
Ε*
Ε
E2b
1
Ε
Ε*
1
Ε
Ε*
8H x + ä y L<
-Ε
9I Hx - ä yL2 M= 9I Hx + ä yL2 M=
Usually, you must use Extend on the character vectors to make them into skewers. But here all classes contain only a single element, so the skewers are identical to the character vectors, and you can read them right from the table. Note that Ε = Exp[2Π ä/6] = 12 +
ä
3 2
.
Make a multiplication table of all the complex Dot products of the skewers. It uses Conjugate on the second member of each Dot, without which not :
424
Two demonstrations
A
B
E1a
E1b
E2a
E2b
A
6
0
0
0
0
0
B
0
6
0
0
0
0
E1a
0
0
6
0
0
0
E1b
0
0
0
6
0
0
E2a
0
0
0
0
6
0
E2b
0
0
0
0
0
6
Fig. 33.2 The diagonal elements should be group order (6) divided by species dimension (always 1 in this group). Indeed, they are.
The Great Orthogonality is verified for group C6 .
33.3.2 With a two-dimensional rep The real power of the Great Orthogonality is in groups with multidimensional representations. Group C3 v is one of the simplest : gp = "C3v"; BoxedCharacterTable@gp D C3v
1
2
3
¬ Class populations
A1
E 1
C3 1
Σv 1
A2
1
1
-1
Basis functions 8H z L, H x2 + y2 L, H z2 L< 8H Iz L<
E
2 -1
0 :K
x O, y
1 2
Ix2 - y2 M xy
,K
xz Ix O, K O> yz Iy
It will have six skewers: One for A1 , one for A2 , and four for E. But class C3 has two members and class Σv has three members, so to turn the character vectors into full skewers, the second character element must be repeated twice; the third, three times. This is done by the Extend operator : skewerA1 = ChVec@"A1", gpD Extend@ð, gpD & 81, 1, 1, 1, 1, 1<
425
Symmetry Theory
skewerA2 = ChVec@"A2", gpD Extend@ð, gpD & 81, 1, 1, -1, -1, -1<
To make the four skewers of rep E, we must first make a representation. The character table says basis polynomials {x,y} should do the job: repExy = MakeRepPoly@8x, y<, "C3v"D; % GridList Size@6D :
1 0
0 1
,
1
3
0 -1
,
1
-
2
1
3
2
2
3
1
2
2
,
-
2
-
2
1 0
3
-
2
, -
1
3
2
2
3
-
2
1
-
2
,
1 2
3
>
2
3
1
2
2
It never hurts to make sure: MorphTest@repExy, "C3v"D Faithful, or Isomorphic
We make all four E skewers at once, then Join them to the A1 and A2 skewers: skewersE = Table@Skewer@repExy, i, jD, 8i, 1, 2<, 8j, 1, 2
1 1
1
-2
0 0 1
1 1
1
-
1
-2
3
3
2 3 2
- 12
2
-
3 2
- 12
1 -1
1 -1
1 -1
1
-2
1
-2
0 0 -1
3 2 3 2 1 2
1
-
3 2 3 2 1 2
Make a vector multiplication table. We got a little carried away and colored it:
426
Two demonstrations
E1,1 E1,2 E2,1 E2,2
A1
A2
A1
6
0
0
0
0
0
A2
0
6
0
0
0
0
E1,1
0
0
3
0
0
0
E1,2
0
0
0
3
0
0
E2,1
0
0
0
0
3
0
E2,2
0
0
0
0
0
3
Fig. 33.3 Green indicates the zeroes that come from a mismatch in species indices, while blue marks the zeroes that come from a mismatch of matrix indices. The diagonal elements should be group order (6) divided by species dimension (1 or 2). Indeed, they are.
The Great Orthogonality is verified for group C3 v . The Great Orthogonality is not an ancient truth, handed down from time immemorial. It is a jewel in the crown of modern Western Civilization, your own heritage. So buckle down and follow the general proof. It is not that hard.
33.4 Proof of the Great Orthogonality 33.4.1 How Schur's Lemmas help The proof is remarkably easy, after the results of the Chapter 30 ((SchursFirstLemma) and Chapter 31 (SchursSecondLemma). The proof is divided into two parts; the first uses Schur's First; the second, Schur's Second. The first says certain universal commuters can only be constant matrices; the second says that certain others can only be zero. Both contain the famous arbitrary Q matrix, and a clever choice of Q in both cases leads directly to the Great Orthogonality. We assume in the proof below that the representations of the group are unitary. But the theorem of Chapter 29 (MakeUnitary) says that every rep is similar to a unitary rep. If your rep of interest is nonunitary, run the package operator MakeUnitary on it, and in that guise it will behave as required below.
33.4.2 Orthogonality within reps
427
Symmetry Theory
33.4.2 Orthogonality within reps Let A be an irreducible rep. There is always a universal commuter matrix C for this rep, and Schur's First Lemma says that it can only be c U, a constant matrix. Therefore c U = Ú A L .Q.A-1 L
(33.2)
L
or in index notation c ∆Μ,Α =
Ú HA L LΜ,k Qk,m IA-1 L Mm,Α
L,k,m
(33.3)
Choose Q to be all zeroes except for a 1 in some one element. If it is the 2,3 element we would write it as ∆k,2 ∆m,3 because TableA∆k,2 ∆m,3 , 8k, 3<, 8m, 3<E MatrixForm 0 0 0 0 0 1 0 0 0
More generally, let the position of the unique 1 be chosen as Ν,Β : c ∆Μ,Α =
Ú HA L LΜ,k ∆k,Ν ∆m,Β IA-1 L Mm,Α
L,k,m
(33.4)
The ∆ functions allow us to perform the sums over k and m symbolically: c ∆Μ,Α = ÚL KA L O
Μ,Ν
IA-1 L M Β,Α
(33.5)
Symbols Μ and Α appear on both sides, so they are completely free. Let Μ ® Α, and sum on Α from 1 to d, the dimension of the rep ÚdΑ=1 c ∆Α,Α = ÚdΑ=1 ÚL KA L O
Α,Ν
IA-1 L MΒ,Α
(33.6)
On the left, ∆Α,Α is always 1, and the sum then gives c d. On the right we swap the two A factors to put their Α indices adjacent (because a sum over adjacent repeated indices is a dot product). Also we swap the order of summation. c d = ÚL ÚdΑ=1 IA-1 L MΒ,Α KA L O
Α,Ν
(33.7)
On the right the parenthesis is the dot product of mutually inverse matrices, so it gives the unit matrix ∆Β0 ,Ν0 : c d = ÚL ∆Β,Ν 428
(33.8)
Proof of the Great Orthogonality
c d = ÚL ∆Β,Ν The sum over L is just h repeats of the unit matrix ∆Β,Ν , so c = Hh dL ∆Β,Ν
(33.9)
Hh dL ∆Β,Ν0 ∆Μ,Α = Ú HA L LΜ,Ν IA-1 L MΒ,Α
(33.10)
Now go back to Eq. 33.5, insert this expression for c L
and use the unitarity of AL :
Hh dL ∆Β,Ν ∆Μ,Α = Ú HA L LΜ,Ν IAT* L MΒ,Α
(33.11)
Hh dL ∆Μ,Α ∆Ν,Β = Ú HA L LΜ,Ν HA*L LΑ,Β
(33.12)
L
or finally
L
On the right we have the h-dimensional complex dot product of two skewers from within rep A ; the left side says that dot product is zero unless Μ = Α and Ν = Β; i.e., unless it is a skewer dotted with itself. We also get the length squared of each skewer : it is h d. So the first part of the Great Orthogonality is proved.
We have written this for a rep called A. But A is some rep number i, so to include the i in the notation, we let A L ® GHiL @LD and A*L ® IGHiL @LDM : *
h
HiL Μ,Ν @LD
SG L=1
HiL
K GΑ,Β @LDO
*
=
h ∆Μ,Α ∆Ν,Β d@iD
(33.13)
33.4.3 Orthogonality between reps Now for the second part. Let reps A and B be inequivalent irreducible reps. There is always a pseudocommuter matrix P for these reps, but because they are inequivalent and irreducible, Schur's Second Lemma says that the pseudocommuter can only be zero. Thus for any matrix Q we have the equation Ú A L .Q.B-1 L = 0
(33.14)
Ú HA L LΜ,Ξ QΞ,Η IB-1 L MΗ,Α = 0
(33.15)
h
L=1
or with explicit sums instead of Dot products L,Ξ,Η
Just as in the first part, we are free to pick Q to be all zeroes except for (33.8) the Ν,Β 429 element, which is 1. This means that QΞ,Η = ∆Ξ,Ν ∆Η,Β . Also, by unitarity, T* B-1 L = BL . Therefore
Symmetry Theory
Just as in the first part, we are free to pick Q to be all zeroes except for the Ν,Β element, which is 1. This means that QΞ,Η = ∆Ξ,Ν ∆Η,Β . Also, by unitarity, T* B-1 L = BL . Therefore
Ú HA L LΜ,Ξ ∆Ξ,Ν ∆Η,Β IBTL * MΗ,Α = 0
L,Ξ,Η
(33.16)
or carrying out the sum over Ξ and Η and transposing BTL *
Ú HA L LΜ,Ν HB*L LΑ,Β = 0
(33.17)
L
Indices Μ,Ν and Α,Β can be whatever you like; for as long as A and B are inequivalent and irreducible, the value is that zero on the right. Thus all skewers from different irreducible reps are orthogonal. If we let A L ® GHiL @LDand B*L ® IGHjL @LDM
*
we have the second part of the Great Orthogonality in
standard notation : h
HiL Μ,Ν @LD
SG L=1
HjL
K GΑ,Β @LDO = 0, *
for i ¹ j
(33.18)
33.4.4 Grand conclusion We can write the first part and the second part as a single equation if we insert ∆i,j on the right side of Eq. 33.13, the first part conclusion. If i ≠ j, you have the second part case, and the ∆i,j = 0 rules. If i = j, you have the first part case, and the other two ∆ functions rule. So we have in both cases h
HiL Μ,Ν @LD
SG L=1
which was to be shown.
430
HjL
K GΑ,Β @LDO
*
=
h ∆ ∆ ∆ d@iD i,j Μ,Α Ν,Β
(33.19)
34. Character orthogonalities Preliminaries
34.1 Introduction and demonstrations 34.1.1 Introduction The character orthogonalities are special cases of the Great Orthogonality. They can be seen directly in all character tables. This is also the chapter where we prove that the character table is square, and that it has an inverse. So perk up. The symbol X is a DoubleStruckCapitalX. We will write X when we mean a character matrix without explicit indices, or Χspecies,CLASS when indices are explicit. The species index (or irreducible representation index) will be a lower case letter, the CLASS index will be upper case. Thus character tables are * . symbolized as X or Χs,C . Or, transposed and conjugated, as XÖ or ΧC,s Here is a fine point of the notation in this chapter. We will never write both a dagger and explicit indices on the same anchor symbol. If X = Χs,C then its * . Since the dagger already implies conjugate-transpose (or adjoint) is XÖ = ΧC,s Ö * . That is dangerously subject to transpose, ΧC,s would have to mean Χs,C
misunderstanding, so we stay away from it by simply making a rule that we never put a dagger and explicit indices on the same anchor.
Ö
* ) for the We will also need symbols X or Χs,L (and their adjoints X or ΧL,s
extended characters, where a capital Greek index (like L) runs over all the elements of the group. The double-headed overarrow is the reminder that when
X is translated to subscript notation, its second index must be capital Greek. So
Ö
X is generally a wide rectangular matrix; its adjoint X is tall. There are two important orthogonalities that exist within the character table of every group. We introduce them by numerical example.
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_34, © Springer Science+Business Media, LLC 2009
431
Symmetry Theory
34.1.2 Column orthogonality demonstration Set up to work with group T, all the rotations of a tetrahedron: grp = "T"; toΕ = :-
1 2
-
ä
3
® Ε, -
2
1 2
+
ä
3 2
® Ε* >;
Call up its character vectors : X = ChVecs@grpD; % . toΕ GridForm 1 1 1 3
1 Ε Ε* 0
1 Ε* Ε 0
1 1 1 -1
The character vectors are the rows of this matrix. We will need its Adjoint : XÖ = X Transpose Conjugate; % . toΕ GridForm 1 1 1 1
1 Ε* Ε 1
1 Ε Ε* 1
3 0 0 -1
We Dot each column of X with every other column by putting the Adjoint on the left of the Dot product : XÖ .X Simplify GridForm 12 0 0 0
0 3 0 0
0 0 3 0
0 0 0 4
The column orthogonality has been demonstrated. On your own 1. Call up the BoxedCharacterTable to see that X is the “center of the table”. 2. Change grp and rerun these orthogonalities. Use a group with complex-valued characters (S4 or S8 , for example).
34.1.3 Row orthogonality demonstration 432
Introduction and demonstrations
34.1.3 Row orthogonality demonstration The character vectors have one element for every class in the group. The whole table contains one vector for every species in the group. Now we define the extended character vector which has one element for every element in the group. They make a rectangular matrix (# species) ´ (# elements) :
X = AllExtendedChVecs@grpD; % . toΕ GridForm Size@7D 1 1 1 3
1 Ε Ε* 0
1 Ε Ε* 0
1 Ε Ε* 0
1 Ε Ε* 0
1 Ε* Ε 0
1 Ε* Ε 0
1 Ε* Ε 0
1 Ε* Ε 0
1 1 1 -1
1 1 1 -1
1 1 1 -1
Note the repeating columns: the class populations are {1,4,4,3}. X = X Transpose Conjugate; % . toΕ GridForm Size@7D Ö
1 1 1 1 1 1 1 1 1 1 1 1
1 Ε* Ε* Ε* Ε* Ε Ε Ε Ε 1 1 1
1 Ε Ε Ε Ε Ε* Ε* Ε* Ε* 1 1 1
3 0 0 0 0 0 0 0 0 -1 -1 -1
X.X Expand; % GridForm Size@7D Ö
12 0 0 0
0 12 0 0
0 0 12 0
0 0 0 12
The row orthogonality has been demonstrated. Are you surprised that two rectangular matrices can Dot to give a unit matrix ? (Well, a multiple thereof) Two rectangular matrices of size long ´ short and short ´ long are said to be pseudoinverse if their short ´ short product is a unit matrix. There is a discussion of this, and of the core operator PseudoInverse, in the MatrixReview. Unlike true inverses, pseudoinverses do not give a unit matrix in the other order. Try it : 433
Two rectangular Symmetry Theory matrices of size long ´ short and short ´ long are said to be pseudoinverse if their short ´ short product is a unit matrix. There is a view. Unlike true inverses, pseudoinverses do not give a unit matrix in the other order. Try it : X .X Expand GridForm Size@7D Ö
12 0 0 0 0 0 0 0 0 0 0 0
0 3 3 3 3 0 0 0 0 0 0 0
0 3 3 3 3 0 0 0 0 0 0 0
0 3 3 3 3 0 0 0 0 0 0 0
0 3 3 3 3 0 0 0 0 0 0 0
0 0 0 0 0 3 3 3 3 0 0 0
0 0 0 0 0 3 3 3 3 0 0 0
0 0 0 0 0 3 3 3 3 0 0 0
0 0 0 0 0 3 3 3 3 0 0 0
0 0 0 0 0 0 0 0 0 4 4 4
0 0 0 0 0 0 0 0 0 4 4 4
0 0 0 0 0 0 0 0 0 4 4 4
It is certainly not a unit matrix. Here it gave a block diagonal matrix, but the MatrixReview shows that in random numerical cases, it just gives a mess. On your own Go back to the top of this section, reset grp to some other group name. If it is complex, you may have to change the definition of Ε and Ε* also. Then evaluate down to here. Do this for several groups.
34.2 Row orthogonality proof Now that you have seen numerical examples of the character orthogonalities, you must be eager to see how they relate to the Great Orthogonality, which is h
HiL Μ,Ν @LD
SG L=1
HjL
K GΑ,Β @LDO
*
=
h ∆ ∆ ∆ d@iD i,j Μ,Α Ν,Β
(33.19)
We take the diagonal case by letting Μ ® Ν and Α®Β. On the left, this specifies the diagonal elements of the G matrices. On the right, it causes ∆Μ,Α ∆Ν,Β ® ∆Ν,Β ∆Ν,Β = ∆Ν,Β . Then sum both sides on Ν and Β from 1 to the dimension of the representation. This gives h
d@iD
S S L=1
Ν=1
HiL Ν,Ν @LD
G
d@jD
S Β=1
HjL Β,Β @LD
G
*
=
h ∆ d@iD i,j
d@iD d@jD
S S
Ν=1 Β=1
∆Ν,Β
On the left each inner sum produces the character of the representation matrix, * Χi,L and IΧj,L M , respectively. On the right every summand vanishes except when Ν = Β, so the sum over Β gives 1. Then summing that 1 over Ν from 1 to 434 d[i] gives d[i], which cancels with the d[i] in the denominator of the prefactor, leaving
Row orthogonality proof
On the left each inner sum produces the character of the representation matrix, * Χi,L and IΧj,L M , respectively. On the right every summand vanishes except when Ν = Β, so the sum over Β gives 1. Then summing that 1 over Ν from 1 to d[i] gives d[i], which cancels with the d[i] in the denominator of the prefactor, leaving The long row orthogonality
Ú Χi,L IΧj,L M = h ∆i,j h
*
(34.1)
L=1
i and j index species; L indexes elements; h = group order Now IΧj,L M can also be written as IΧL,j M (because the transpose T plus the T
explicit index reversal undo each other). Χi,L IΧL,j M
T*
This makes Χi,L IΧj,L M
*
into
which has the summed indices L adjacent.
In Χi,L index i runs over the species of the group (NS of them), while L runs over all elements of the group (NE of them). So Χi,L is rectangular, of size NS Ö
´ NE, We let it be matrix X in subscript-free notation. Its adjoint X is therefore of size NE ´ NS, and the dot product (NS ´ NE).(NE ´ NS) is a matrix of size NS ´ NS. So the long row orthogonality can be written very neatly as The long row orthogonality as a Dot product
Ö
(34.2)
X . X = h UNS´NS where UNS´NS is a unit matrix of size NS ´ NS. There is a lot of redundancy in the long character vector Χi,L because its value for every element in a given class is the same. Therefore as L runs over a class, * all the summands Χi,L Χj,L in that class are identical, and may be denoted by * , where C is a class index. If the population of the class is P , then the Χi,C Χj,C C * , and we may rewrite the sum contribution of the whole class is PC Χi,C Χj,C
over elements L as a sum over classes C
435
Symmetry Theory
The short, weighted row orthogonality * M = h∆ Ú PC IΧi,C Χj,C i,j NC
(34.3)
C=1
i and j index species; C indexes classes; NC = number of classes
To rewrite this symmetrically, divide both sides by h and let
Y (size NS ´ NC) and let
PC h
PC h
Χi,C ®
T* ® YÖ (size NC ´ NS) . The number of ΧC,j
columns of Y is the same as the number of rows of YÖ , so the sum over them can be written as a dot product. Letting ∆i,j be the unit matrix U of size NS ´ NS we can write The short row orthogonality as a Dot product
(34.4)
Y.YÖ = UNS´NS We will prove that Y is square, but we did not have to assume it to reach this conclusion.
34.3 Column orthogonality proof The proof of column orthogonality cannot assume that the character table, viewed as a matrix X, is square. It is true, but we have not proved it yet. It is not hard to find books with bogus “ proofs” of column orthogonality that assume the square shape without proving it. There is another class of bogus proofs in which X is assumed to have an inverse without proving it. Here is a real proof that does not assume that X is square, nor that it has an inverse. It is necessarily a bit lengthy, so get ready. Let Χs,C be the character table, where s labels the rows of irreducible representations (also called symmetry species) and C labels the classes. The rows of the table (known by the previous theorem to be orthogonal) span a vector space, in which the general vector, constructed with arbitrary coefficients as , is g = gC = Ú as Χs,C NS
436
s=1
(34.5)
Column orthogonality proof
g = gC = Ú as Χs,C NS
s=1
The strategy of this proof is a little unusual, and you should be forewarned about it. We are going to construct a matrix M and show that g.M º g, no matter what g is. From this we will conclude that M must be the unit matrix. The column orthogonality is then written as MC,D == ∆C,D . The species index s runs from 1 to NS, the (unknown) number of species. Now make a scalar product of this arbitrary vector with the adjoint of the character table. We write it as a sum over classes, so the population factor PC must be included. * = Ú Ú gC PC ΧC,r
* Ú as PC Χs,C ΧC,r
NC
NC
NS
C=1
C=1 s=1
(34.6)
Switch the order of summation on the right * * N = Ú as Ú PC JΧs,C ΧC,r Ú gC PC ΧC,r
NC
NS
NC
C=1
s=1
C=1
(34.7)
But the sum over C on the right is the weighted row orthogonality, so * = Ú as Ú gC PC ΧC,r
NC
NS
C=1
s=1
h ∆s,r
(34.8)
Do the sum over s: * = h ar Ú gC PC ΧC,r
NC
(34.9)
C=1
Divide both sides by h, multiply by Χr,D , and sum over r : NS NS 1 NC NC = Ú Ú a ∆ Χ Ú Ú g P Χ* Χ h r=1 C=1 C C C,r r,D r=1 s=1 s s,r r,D
(34.10)
On the right, the sum over r can be done explicitly. On the left, move the sum over r as far inward as possible : NC NS 1 NC = Ú a Χ Ú g P Ú Χ* Χ h C=1 C C r=1 C,r r,D s=1 s s,D
(34.11)
But the sum over s is the general vector g that we first wrote in Eq. 34.5, so
Ú gC NS
C=1
PC h
* Χr,D = gD Ú ΧC,r NS
(34.12)
r=1
But g was absolutely arbitrary, so the parenthesis cannot contain anything other than ∆C,D . Therefore we can conclude (34.5)437
Symmetry Theory
But g was absolutely arbitrary, so the parenthesis cannot contain anything other than ∆C,D . Therefore we can conclude The column orthogonality
Ú PhC NS
* ΧC,s Χs,D = ∆C,D
(34.13)
s=1
C and D index classes, s indexes species.
As before, let
PC h
Χs,D
® Y (size NS ´ NC) and let
PC h
* ΧC,s ®
YÖ (size NC ´ NS) . The sum is over s, so the dot product is of size (NC ´ NS).(NS ´ NC). Therefore ∆C,D is a unit matrix of size NC ´ NC : The column orthogonality as a Dot product
(34.14)
YÖ .Y = UNC´NC
34.4 Character tables are square Now we are ready to draw one of the most important conclusions in representation theory. It will be quick. We have deduced the orthogonalities YÖ .Y = UNC´NC
and
Y.YÖ = UNS´NS
(34.15)
But we do not know whether NC (the number of classes) is the same as NS (the number of species), or not. If they are not the same, the YÖ .Y product is a rectangular multiplication of size (NC ´ L).(L ´ NC), where L is unknown. And the other orthogonality says the Y.YÖ multiplication is of size (NS ´ M).(M ´ NS), with M unknown. So by one reasoning Y must be of size (L ´ NC), and by the other it must be of size (NS ´ M). But it is the same matrix, so the unknown L must be NS, and the unknown M must be NC. Now the size of Y can be expressed both as (NS ´ NC) and as (NC ´ NS). But both of these ways can be true only if NS = NC, so :
438
Character tables are square
The weighted character table Y of every group is square. But its size is the same as the unweighted character table X , which must also be square. That is, the number of classes is identical to the number of irreducible representations (or species). We have also proved another important fact: Instead
of
symmetric
definitions
* ΧC,s ®YÖ , let IΧs,D M®X and J
PC h
~
making
~
PC h
PC * ~ ΧC,s N® X. h
Χs,D ®Y
and
We showed that
~
X.X = X.X = U, so matrices X and X meet the complete definition of mutually inverse matrices.
~
So the character table X of every group has an inverse, given by X.
34.5 Check the twiddle matrix numerically Too much index manipulation makes some people uneasy, and well it should; it is so easy to make a mistake. Fortunately, you can now check it numerically. Try the following with any group. Just change the grp name at the top. grp = "T"; h = GroupOrder@grpD; X = ChVecs@grpD; % GridForm Size@6D; 1 1
1 3
1 -
1
-
1
2
2
+
1
ä
3 2
ä
3 2
-
1
-
1
2
2
0
+ -
1
ä
3
1
2 ä
3
1
2
0
-1
P = ClassPopulations@grpD 81, 4, 4, 3<
Here is the construction we are checking, the twiddle matrix : 439
Symmetry Theory
Here is the construction we are checking, the twiddle matrix :
X = P * Transpose@Conjugate@XDD h Expand;
~
% GridForm 1 12 1 3
1 12
- 16 +
1 3
- 16 -
1 4
1 12 ä
2
- 16 -
3 ä
2
- 16 +
3
1 4
1 4 ä
2
0 3
ä 2
0 3
1 4
- 14
Test both the left and right orthonormalities : :X.X, X.X> Simplify;
~ ~
% GridList Size@7D :
1 0 0 0
0 1 0 0
0 0 1 0
0 0 0 1
,
1 0 0 0
0 1 0 0
0 0 1 0
0 0 0 1
>
34.6 Unique rows and columns We now know that the character table X of every group possesses an inverse,
~
given by X. This implies that the determinant of X is nonzero. But if two rows are equal, or if two columns are equal, (or even proportional) the determinant must vanish. So X has unique, linearly independent columns and unique, linearly independent rows. This is a major result: Each row of the character table identifies its irreducible representation uniquely, and each column identifies its class uniquely.
34.7 A theorem of your very own The following exercises have more meat than usual :
440
A theorem of your very own
1. Let d be a list of the dimensions of all the irreducible reps of a group, and let h be its order. Write a Module that you can Map onto GroupCatalog, returning a list {groupname,h,Úhi=1 dPiT,Úhi=1 dPiT2 }. You will make a surprising numerical discovery. Module construction is a basic Mathematica skill, but if you still need help with it, click here.
2. Firm up your discovery with a symbolic proof. Think outside the lines a little. What other quantity do you know that is always equal to h? For the answer, click here.
34.8 End Notes
34.8.1 A surprising regularity Look at the list you will Map onto : GroupCatalog
8C1, C2, C2h, C2v, C3, C3h, C3v, C4, C4h, C4v, C5, C6, C6h, C6v, Ch, Ci, D2, D2d, D2h, D3, D3d, D3h, D4, D4d, D4h, D5, D5d, D5h, D6, D6d, D6h, I, O, Oh, S4, S6, S8, T, Td, Th<
Remember that the first element of every character vector is the dimension of the representation. expt@g_StringD := Module@8dvec, h<, dvec = Transpose@ChVecs@gDDP1T; h = GroupOrder@gD; 8g, h, Apply@Plus, dvecD, dvec.dvec
441
Symmetry Theory 8C2h, 4, 4, 4< 8C6, 6, 6, 6< 8D4h, 16, 12, 16< 8S6, 6, 6, 6<
What are you supposed to see? The first number is the group order, the second is the sum of the species dimensions, and the third is the sum of the dimensions squared. Is it obvious that two of these should always be the same?
34.8.2 The d.d theorem
Let d be a list of the dimensions of all the irreducible reps of a group. In every group, d.d = h. Why does this always hold? Consider a representation in block diagonal form, in which each block is an irreducible representation, and with each rep present once and only once. Each block i is of size d[i]´ d[i]. There is a unique skewer for each element, so the number of skewers in block i is d@iD2 . But we know that the skewers span a space of dimension h, so the total number of skewers is h. Therefore 2 ÚNR i=1 d@iD = d.d = h, which was to be proved. You might think there would be some nice simple formula for the value of ÚNR i=1 d@iD, the dimension of the block diagonal representation considered above. But there isn't. If you can find one, let somebody know.
442
35. Reducible rep analysis Preliminaries
35.1 The point of rep analysis This is the “quick and easy” way to analyze a rep, promised long ago in Chapter 28 (ReducibleRepresentations). We could not present it there because we did not yet have Chapter 33 (TheGreatOrthogonality) and its offspring, CharacterOrthogonalities of Chapter 34. Now we have them, and we can go forward. But first, remember why we need rep analysis. Here is the standard procedure for symmetry analysis, used over and over in applications :
1. Identify N symmetric basis objects b = 8b1 , b2 , ¼, bN < whose symmetry you want to analyze. These could be orbitals, or spectroscopic transition operators, or many other things. These are your basis objects. 2. Let group G be the group of a molecule of interest.
3. Make a representation B of G using b as the basis objects. The command is
B = MakeRepX[8b1 , b2 , ¼, bN <,G], as developed in Chapter 27 (MakeReps). B is a “big” rep, because its N´N matrices are generally bigger than any of the irreducible rep matrices of G. 4. Compute ΧHBL , the short character vector of rep B.
5. Call Analyze[ΧHBL ,G], developed below. This returns all the symmetry information that there is about the list of basis objects, as they relate to your molecule. Now you are ready for the quick and easy analysis method.
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_35, © Springer Science+Business Media, LLC 2009
443
Symmetry Theory
35.2 Symbolic development of Analyze Consider a big, tangled representation B of some group G, and consider also a similarity transform of it, Bblock , in block diagonal form. The transform leaves diagonal sums invariant, so the diagonal sum, or character, of each B matrix is the same as that of the corresponding Bblock matrix. But the blocks are irreducible representations, and their characters are listed in the character table of group G. An irreducible rep may appear in Bblock one time, several times, or not at all. Let the number of times that rep r appears in Bblock be nHBL r . Then the character of each class C of B can be expressed as a weighted sum down the species column of class C in the character table:
This may be better understood from an example diagram. On the left we have a big rep matrix belonging to class C. Its trace, or spur, is a+ b +… + m. On the right, this matrix has been block diagonalized. A matrix from rep B
a
Same matrix from rep B block
x x x x x x x x x x
x
x b x x x x x x x x x x x c x x x x x x x x
x x
x x x d x x x x x x x x x x x e x x x x x x
x x
x x x x x f x x x x x x x x x x x g x x x x
x x
A ì ì ì B ì ì ì C
0
0
0
0
0
0
0 0
0
0
0
0
0
0
0
0 0
0
0
0
0
0
0
0
0 0
0
0
0
0
D
æ
0
0
0
0
0 0
0
0
0
0
æ
E
0
0
0
0
0 0
0
0
0
0
0
0
0
0 0
0
0
0
0
0
0
0
0 0
0
0
0 0
0
x x x
x
0
0
0
0
0
A ì ì ì B ì ì ì C
i
x x
x
0
0
0
0
0
0
0
0
D
æ 0
0
j
x
x
0
0
0
0
0
0
0
0
æ
E
0
0
x x x x x x x x x x k x x x x x x x x x x x
x
0
0
0
0
0
0
0
0
0
0
F
0
m
0
0
0
0
0
0
0
0
0
0 0
G
x x x x x x x
h
x x x x x x x x
x x x x x x x x x
®
By similarity we know that the two traces are equal
Ha + b + ¼+ mL = HA +B +CO+HD + EL+HA + B + CL+HD + EL+F+G Suppose
that you have gone through the clumsy analysis procedure of Chapter 28 (ReducibleRepresentations), and you know that while
D
ì
ì
E
A ì ì ì B ì ì ì C
is from species 6,
is from species 5, and E, F, and G are from species 1, 2, and 3,
respectively. Then you can rewrite the diagonal sums as HGL
Ja +b +¼+mN = H1 * Χ1
+ I1 * Χ2HGL M +
I1 * Χ3HGL M + I0 * Χ4HGL M + I2 * Χ5HGL M + I2 * Χ6HGL M
These matrices belong to some class C of the group, so Ja +b +¼+mN is the 444 character of the whole class C of rep B, symbolized as ΧCHBL . Similarly, the Χ's on the right side also belong to the whole class C, so we write it s a Dot product with class C specified on both sides :
Symbolic development
These matrices belong to some class C of the group, so Ja +b +¼+mN is the character of the whole class C of rep B, symbolized as ΧCHBL . Similarly, the Χ's on the right side also belong to the whole class C, so we write it s a Dot product with class C specified on both sides : ΧCHBL = 81, 1, 1, 0, 2, 2<.8Χ1,C , Χ2,C , Χ3,C , Χ4,C , Χ5,C , Χ6,C <
Now let {1,1,1,0,2,2} be the species count vector n. It is specific to rep B of group G, so we give it the superscript(B,G). Also the Χ vector above is just a row from the character table of group G, with standard symbol ΧHGL . Now the C
right side becomes a Dot product of two vectors : ΧCHBL == nHB,GL .ΧHGL C
(35.1)
The class index C appears on both sides above, meaning that this equation holds for all classes. Therefore we can replace it by a vector underscript on the left, (the vector running over classes) while on the right when C runs over all classes in ΧHGL you have the character matrix XHGL . So this equation, holding for all C
classes and all species at once, is
ΧHBL == nHB,GL .XHGL
(35.2)
We now know that the number of classes is the same as the number of irreducible representations, so ΧHBL and nHB,GL are vectors of same length N, and XHGL is a matrix of size N ´N, In easy cases you can solve this by mental arithmetic. Write the character vector ΧHBL on a piece of paper and slip it up against the bottom of the character
table XHGL . For each class, run your finger down the column while thinking what coefficient vector nHB,GL will make the sum shown on the paper for ΧHBL . When you have one set of coefficients that makes all the characters correct, you have solved the problem. But if this takes more than a few seconds, feed it to LinearSolve and get the answer without human thought : Quick and easy rep analysis nHB,GL == LinearSolveBTransposeAXHGL E, ΧHBL F
(35.3)
That's all there is to it.
445
Symmetry Theory
On your own Pull up the syntax of LinearSolve and see why we had to Trans pose XHGL before we used it. Of course, if you insist, it can also be solved symbolically. The character matrix
~ HGL
XHGL has an inverse X
~
given by
HGL
X
=
1 HGL P * IXHGL Ö M h
~ HGL
where PHGL is the class population vector for group G. So dotting X
in on
the right of Eq. 35.2 we isolate the unknown n vector: Not quite so quick and easy rep analysis nHB,GL == ΧHBL .J
1 P * IXHGL Ö MN h
(35.4)
The Dot runs over classes If you think that P vector makes it too complicated, you can change the short characters to long characters, and change the sum over classes into a sum over elements. Then Another pretty quick and easy rep analysis nHB,GL ==
HGL Ö 1 HBL Χ .X h
(35.5)
The Dot runs over elements
35.3 Numerical example of rep analysis We continue with the benzene example we have used throughout the book. We have a handy operator that cuts through the Gordian knot of rep construction. Use it to construct a rep on the basis of the six Π orbitals of benzene : grp = "D6h"; B = MakeRepAtomic@"benzene", grp, , 446
DP1T;
Numerical example
grp, atomKind ® "C", preFactor ® zDP1T; MorphTest@%, grpD Faithful, or Isomorphic
Sum up the diagonals of all 24 matrices, and select the first from each class : ΧHBL = Map@Spur, BD OnePerClass@ð, grpD &
86, 0, 0, 0, 0, -2, 0, 0, 0, -6, 2, 0<
This is the character vector to be analyzed. We pull up the square essentials from the character table : XHGL = ChVecs@grpD;
The next line solves the problem:
nHB,GL = LinearSolveBTransposeAXHGL E, ΧHBL F Simplify 80, 0, 1, 0, 1, 0, 0, 1, 0, 0, 0, 1<
To make it more easily readable by humans, pull the species names and bracket them with the number of occurrences : TransposeB:SpeciesNames@grpD, nHB,GL >F
88A1g, 0<, 8A2g, 0<, 8B1g, 1<, 8B2g, 0<, 8E1g, 1<, 8E2g, 0<, 8A1u, 0<, 8A2u, 1<, 8B1u, 0<, 8B2u, 0<, 8E1u, 0<, 8E2u, 1<<
This says that in the block diagonal reduction of rep B, four species appeared one time each; namely, B1 g , E1 g , A2 u , and E2 u . These are exactly the species labels used in Fig. 23. 5, to which you may click back.
35.4 The Analyze operator The procedure of Eq. 35.3 has been immortalized in the Symmetry` package under the name Analyze.
447
Symmetry Theory
Analyze[chVec,"g"] returns the composition of chVec in terms of the irreducible character vectors of group "g".
In Chapter 28 (ReducibleReps) we promised a “quick and easy” way to find the block diagonal components of a big reducible representation. Our example there was a 6 ´6 representation of group D6 h , using as basis functions the six Π orbitals of benzene. We called the rep B , and found its character vector. Here it is again : ΧB = 86, 0, 0, 0, 0, 2, 0, 0, 0, 6, 2, 0<;
Perhaps you recall how much trouble it was to reduce that representation by methods based plainly on the definitions. Compare all that to the use of the Analyze operator : AnalyzeBΧB , "D6h"F Size@8D
88A1g, 1<, 8A2g, 0<, 8B1g, 0<, 8B2g, 0<, 8E1g, 0<, 8E2g, 1<, 8A1u, 0<, 8A2u, 0<, 8B1u, 0<, 8B2u, 1<, 8E1u, 1<, 8E2u, 0<<
That's the complete answer. This problem, rather formidable if done by hand, was solved by three group theoretic operators: First, MakeRepAtomic, then a mapping of Spur, and finally Analyze. You can study the orbitals of any tabulated molecule in any tabulated group the same way. Things are building up.
448
36. The regular representation Preliminaries
36.1 What is the regular representation? Every group has a regular representation that can be constructed solely from knowledge of the group multiplication table. It has two miraculous properties. First, it allows us to determine the total number of irreducible representations that the group possesses. Second, it allows us to construct the character table of the group. We will prove and demonstrate the first property in this chapter, saving the second property for Chapter 48 (MakeCharacterTable). But first, the definition and construction of the regular representation. In Chapter 25 (Representations) we gave the formula for constructing any representation. For element L it was TL @fD = f.THLL
HEq. 25.1 againL
where the vector f was a list of unspecified objects and THLL is the desired (unknown) rep matrix for element L of the group. The only requirement on the f objects is that they be symmetric (or invariant ) under the transform TL @fD for every L in the group. Now we make an ingenious interpretation of the undefined elements of vector f . We take them to be the abstract group elements themselves. Also, we take
the transform rule TL @fD to be multiplication of the element list f by element L. Then the general rep mat definition, Eq. 25.1 becomes concrete as The regular representation
L Ä8E, A, ¼, Z< = 8E, A, ¼, Z< . L
(36.1)
where the abstract group elements are {E,A,… ,Z} (L being some one of them) and the DoubleStruck capitals {E,A,… ,Z} are the representation matrices ( L being the matrix for L) Since the left side is just the Lth-row of the group's multiplication table, all you need is knowledge of that table. By the rearrangement theorem the left side is just a rearrangement of all the group elements, and therefore matrix L on the right has to be a permutation matrix, all zeroes and ones. We can solve this using the package operator MatrixOfCoeffi cients. Here is its thumbnail sketch: W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, 449 DOI 10.1007/b13137_36, © Springer Science+Business Media, LLC 2009
where the abstract group elements are {E,A,… ,Z} (L being some one of them) and the DoubleStruck capitals {E,A,… ,Z} are the representation matrices ( L being the matrix for L) Since the left side is just the Lth-row of the group's multiplication Symmetry Theorytable, all you need is knowledge of that table. By the rearrangement theorem the left side is just a rearrangement of all the group elements, and ones. We can solve this using the package operator MatrixOfCoeffi cients. Here is its thumbnail sketch: MatrixOfCoefficients[exprs,vars] returns matrix MC, where MC.vars == exprs. It may fail if the vars are not simple symbols, and it will fail if the exprs are not linear in the vars.
Note that MatrixOfCoefficients returns a rightward matrix, whereas representation theory requires a leftward matrix. The switch is easy: Write the equation for a rightward matrix, solve it using MatrixOfCoefficients, and then Transpose the result to make it into a leftward matrix. Below, we set grp to be our old war horse, group C3 v . You can either use it as is, or reset it to another group. Everything below should run perfectly for any tabulated group. Begin with the multiplication table for the group : grp = "C3v"; MT = MultiplicationTable@grpD; BoxUp@MT, MTP1T, "C3 v ", .8D C3 v E C3a C3b Σva Σvb Σvc
E E C3a C3b Σva Σvb Σvc
C3a C3a C3b E Σvc Σva Σvb
C3b C3b E C3a Σvb Σvc Σva
Σva Σva Σvb Σvc E C3a C3b
Σvb Σvb Σvc Σva C3b E C3a
Σvc Σvc Σva Σvb C3a C3b E
Define an operator that works on any row of multiplication table MT, returning the regular rep matrix of the corresponding element : RRofMT@row_D := Transpose@MatrixOfCoefficients@row, MTP1TDD Map it over the whole matrix: RegRepC3v = Map@RRofMT, MTD; % GridList Size@7D
450
Regular representation defined
:
1 0 0 0 0 0
0 1 0 0 0 0
0 0 1 0 0 0
0 0 0 1 0 0
0 0 0 0 1 0
0 0 0 0 0 1
0 0 1 0 0 0
1 0 0 0 0 0
0 1 0 0 0 0
0 0 0 0 0 1
0 0 0 1 0 0
0 0 0 0 1 0
0 0 0 0 1 0
0 0 0 1 0 0
0 0 0 0 0 1
0 1 0 0 0 0
1 0 0 0 0 0
0 0 1 0 0 0
,
0 1 0 0 0 0
0 0 1 0 0 0
1 0 0 0 0 0
0 0 0 0 1 0
0 0 0 0 0 1
0 0 0 1 0 0
,
,
0 0 0 1 0 0
0 0 0 0 0 1
0 0 0 0 1 0
1 0 0 0 0 0
0 0 1 0 0 0
0 1 0 0 0 0
,
,
0 0 0 0 0 1
0 0 0 0 1 0
0 0 0 1 0 0
0 0 1 0 0 0
0 1 0 0 0 0
1 0 0 0 0 0
>
That is indeed a fine list of matrices, but does it represent the group ? MorphTest@RegRepC3v, grpD Faithful, or Isomorphic
It does. The representation theorem really works, even with this rather weird interpretation. Condense all this into an operator called MakeRepRegular: MakeRepRegular@grp_D := Module@8MT<, MT = MultiplicationTable@grpD; Map@Transpose@MatrixOfCoefficients@ð, MTP1TDD &, MTDD; Try it out: MakeRepRegular@"C3v"D == RegRepC3v True
Most applied group theory books give a different definition of the regular representation, much better adapted to hand calculation than this one. If you want to see it, click to the End notes of this chapter. It contains a small surprise, not mentioned in any other group theory book we have seen.
451
Symmetry Theory
36.2 Characters of the regular representation Look at the diagonals of the example regular rep computed in the last section. Except in the first matrix (the unit matrix), the diagonals are all zeroes. If there is a 1 on the diagonal, the corresponding element did not move when the transform was applied. That always happens when the transform is multiplication of the group list by E, but it never happens for any other element. But by the rearrangement theorem, when the multiplier is anything else, all the elements move, and the diagonal of the rep matrix is pure zeroes. So the character of the unit matrix is h, the order the group; but for every other matrix, the character is 0. Check it : ΧvecLong = Map@Spur, RegRepC3vD
86, 0, 0, 0, 0, 0<
36.3 The golden property In Chapter 35 (RepAnalysis) the second form of the algebraic formula for rep analysis was nHB,GL ==
1 h
HBL
Χ
HGL Ö
.X
Dot over elements
Replace the B (the B ig rep to be analyzed) by a curly R (the R egular rep), and
HGL Ö
rewrite in index notation. The symbol X HR,GL ns
Remember,
=
HR,GL ns
h
S h 1
HGL ΧHRL L ΧL,s
HGL HGL is IΧs,L M = IΧL.s M : Ö
*
*
L =1
is the number of times that species s appears in the regular
representation R of group G. For the regular representation, ΧHRL L is zero except when L references the unit element E, so in the sum over L , only the term for element E survives : HR,GL
ns But
ΧHRL E is
h, and
HGL * ΧE,s
group G. Therefore, 452
=
1 h
HGL ΧHRL E ΧE,s
*
is the real number dHGL s , the dimension of species s of
But ΧHRL E is h, and
HGL * ΧE,s
The golden property
is the real number dHGL s , the dimension of species s of
group G. Therefore,
HR,GL
ns
= dHGL s
Species s appears in the regular representation R of group G the same number of times as its dimension.
(36.2)
This is a hugely significant result. First of all, every irreducible rep has a dimension of at least 1, so ALL the irreducible representations appear in the regular rep. This means that if we reduce the regular representation we are guaranteed to find every irreducible representation. Nothing before now has guaranteed a way to find them all, much less all at once.
36.4 Demo of the golden property In order to use the golden property, you do not really have to make the whole regular representation at all. In Chapter 48 (MakeCharacterTable) we will need the whole regular representation, but to use the golden property all you need is its character vector, which is predictable: It consists of h, followed by NC-1 zeroes, where NC is the Number of Classes. Here we cook it up for group D6 h : grp = "D6h"; h = GroupOrder@grpD; NC = Length@ClassNames@grpDD; chVecRegRep = Join@8h<, Table@0, 8i, NC - 1
Now apply Analyze to it : Analyze@chVecRegRep, grpD
88A1g, 1<, 8A2g, 1<, 8B1g, 1<, 8B2g, 1<, 8E1g, 2<, 8E2g, 2<, 8A1u, 1<, 8A2u, 1<, 8B1u, 1<, 8B2u, 1<, 8E1u, 2<, 8E2u, 2<<
As advertised, all 12 species are present at least once. All the one-dimensional species (anchored on A or B) appear one time, while all the two-dimensional species (anchored on E) appear two times. If this were an untabulated group, you would have to supply generic species names like Gi . The return would give them all back, each bracketed with its dimension. The dimensions would likely be new information for you.
36.5 The d2 corollary 453
Symmetry Theory
36.5 The d2 corollary Now for a little corollary. The dimension of the regular representation is h, but if it is reduced, its dimension has to be the same as the sum of the dimensions of all the diagonal blocks. Species s contributes ds to this sum, but it does so nHsRL times. Therefore h = Ú nHsRL ds , where NS is the number of species. NS
But we just proved that nHsRL is the same as ds , so s=1
h == â d2s NS
(36.3)
s=1
This is consistent with, but stronger than, the NS inequality that we deduced earlier from the Great Orthogonality.
36.6 End Notes 36.6.1 Alternative construction of the regular rep The alternative algorithm is easy to state in words, and nearly every group theory book does it : (1) Reorder the rows of the group multiplication table so that the unit element falls on the principal diagonal. (2) To make the regular rep matrix for element X, replace every X in the table by 1. Then replace everything else by 0. This is easy for a human with pencil and paper, but a little clumsy to specify for a computer. Besides, this recipe needs a proof that it produces a representation. This was automatically assured for the RegularRep algorithm above, because it starts with the definition of representation. But for the traditionalists out there, here is a demonstration that Mathematica can carry out the traditional construction: grp = "C3v"; h = GroupOrder@grpD
454
End Notes
6
The traditional construction is a little easier if we use the integer name trick. Construct a multiplication table for the group, using integers 1 through h as the names of the elements. MTstd = MultiplicationTable@Dot, CartRep@grpD, Range@hDD; % MatrixForm 1 2 3 4 5 6
2 3 1 6 4 5
3 1 2 5 6 4
4 5 6 1 2 3
5 6 4 3 1 2
6 4 5 2 3 1
Now the product iÄj lies as position Pi,jT in this table. We assume the unit element is the first element, named 1. Use the Position operator to where the 1 is in every row : diagPermStd = Table@Position@MTstdPiT, 1D, 8i, 1, h
Permute the rows so that the unit element falls on the principal diagonal of the multiplication table : MT1 = MTstdPdiagPermStdT; % MatrixForm 1 3 2 4 5 6
2 1 3 6 4 5
3 2 1 5 6 4
4 6 5 1 2 3
5 4 6 3 1 2
6 5 4 2 3 1
Suppose we want the matrix for element number 3 of this group. Replace every 3 by the letter U:
MT2 = MT1 . 83 ® "U"<; % MatrixForm 1 U 2 4 5 6
2 1 U 6 4 5
U 2 1 5 6 4
4 6 5 1 2 U
5 4 6 U 1 2
6 5 4 2 U 1
455
Symmetry Theory
Replace every remaining integer by a zero :
MT3 = MT2 . 8_Integer ® 0<; % MatrixForm 0 U 0 0 0 0
0 0 U 0 0 0
U 0 0 0 0 0
0 0 0 0 0 U
0 0 0 U 0 0
0 0 0 0 U 0
Re-replace every U by a 1 :
MT4 = MT3 . 8"U" ® 1<; % MatrixForm 0 1 0 0 0 0
0 0 1 0 0 0
1 0 0 0 0 0
0 0 0 0 0 1
0 0 0 1 0 0
0 0 0 0 1 0
and that is the regular rep matrix for element #3. Put these operations together into a new alternate operator MakeRepRegularRepAlt : MakeRepRegularAlt@grp_D := Module@8h, MTstd, diagPermStd, MTreordered, MakeRRmat, n<, h = GroupOrder@grpD; MTstd = MultiplicationTable@ Dot, CartRep@grpD, Range@hDD; diagPermStd = Table@Position@MTstdPiT, 1D, 8i, 1, h
456
End Notes
:
1 0 0 0 0 0
0 1 0 0 0 0
0 0 1 0 0 0
0 0 0 1 0 0
0 0 0 0 1 0
0 0 0 0 0 1
0 0 0 1 0 0
0 0 0 0 1 0
0 0 0 0 0 1
1 0 0 0 0 0
0 1 0 0 0 0
0 0 1 0 0 0
,
0 0 1 0 0 0
1 0 0 0 0 0
0 1 0 0 0 0
0 0 0 0 1 0
0 0 0 0 0 1
0 0 0 1 0 0
,
0 0 0 0 1 0
0 0 0 0 0 1
0 0 0 1 0 0
0 0 1 0 0 0
1 0 0 0 0 0
0 1 0 0 0 0
,
0 1 0 0 0 0
0 0 1 0 0 0
1 0 0 0 0 0
0 0 0 0 0 1
0 0 0 1 0 0
0 0 0 0 1 0
,
0 0 0 0 0 1
0 0 0 1 0 0
0 0 0 0 1 0
0 1 0 0 0 0
0 0 1 0 0 0
1 0 0 0 0 0
,
>
The two algorithms do not have to produce identical reps. But did they? RegRepC3vAlt == RegRepC3v False
On your own They are not the same, but you can prove that they are similar. You have all the tools.
457
37. Projection operators Preliminaries
37.1 Projection operators in geometry In geometry, a projection matrix can project out one component of a vector: x 1 0 0 0 0 0 . y z 0 0 0
==
x 0 0
The projection matrix is idempotent: any power is simply the matrix itself : 1 0 0 1 0 0 1 0 0 0 0 0 . 0 0 0 . 0 0 0 0 0 0 0 0 0 0 0 0
==
1 0 0 0 0 0 0 0 0
True
Therefore, no matter how many times you apply the x-projection matrix to {x,y,z}, the answer is always {x,0,0}. The projection operators of group theory are similar, but they operate in function spaces rather than in Cartesian space. The determinant of projection matrices is zero, and they have no inverse. Therefore, projections cannot be undone. This makes perfect sense, because projections entail an irreversible loss of information in the dimensions that are wiped out. However, if you had a complete set of projections (like the x, y, and z projections) their sum would be the original.
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_37, © Springer Science+Business Media, LLC 2009
459
Symmetry Theory
37.2 Projection operators in algebra 37.2.1 The basic idea The simplest example of function space projection is no doubt already familiar to you; it is the splitting of any function of one variable into parts of positive and negative “ parity”. If f[z] is any function, then (f[z]+f[-z])/2 is invariant when z changes sign. On the other hand, the function (f[z]-f[-z])/2 changes its sign, but not its absolute value, when z changes sign. The first is said to be of “ even parity”; the second, of “ odd parity”. Note that they add to make the original f[z] again. This extends easily to three dimensions. The inversion operator changes the sign of all three axes, and any function of x,y,z can be split into parts that are even and odd with respect to inversion. In the Symmetry` package there are two kinds of group theoretic projection operators, and they will be derived in detail in this chapter. But as an introduction, here is your a first example: ProjectET@f@x, y, zD, "Ci"D Expand ::Ag,
1
f@-x, -y, -zD +
2
:Au, -
1 f@x, y, zD>, 2
1 2
f@-x, -y, -zD +
1 f@x, y, zD>> 2
We specified group Ci above. It consists of only the identity and the inversion, and the projector returned two functions, one even and one odd with respect to inversion. What are those symbols Ag and Au? They are the names of the irreducible representations (or “ symmetry species”) of group Ci : BoxedCharacterTable@"Ci"D Ci 1
1
¬ Class populations
E inv Basis functions Ag 1 1 8x ^ 2<, 8y ^ 2<, 8z ^ 2<, 8x * y<, 8x * z<, 8y * z<, 8Ix<, 8Iy<, 8Iz< Au 1 -1 8H x L, H y L, H z L<
The g stands for the German word gerade (even) and u stands for ungerade (odd). The projection operator for group Ci splits the general function f[x,y,z] into two parts; one is a basis for rep Ag ; the other, for Au . Here is a concrete example, with graphics : 460
Algebra
The g stands for the German word gerade (even) and u stands for ungerade (odd). The projection operator for group Ci splits the general function f[x,y,z] into two parts; one is a basis for rep Ag ; the other, for Au . Here is a concrete example, with graphics : 1
+ 2 x2 + x3 ; 2 ProjfCi = ProjectET@f@xD, "Ci"D ExpandAll f@x_D := ::Ag,
1 2
+ 2 x2 >, 9Au, x3 =>
Whole function: 8
-2
Even part:
1 2
+2x2 +x3
2
1 2
+2 x2 Species Ag
Odd part: x3 Species Au 8
8 -2
-2
2
2 -8
Fig.37.1 An asymmetric function, f@xD, is split into two parts, odd and even with respect to reflection at the origin.
The concept of splitting a function into symmetric parts is marvelously generalized in group theory. The next section shows a quite simple example that would be very tedious to think through from first principles.
37.2.2 Introductory example (group D4 ) Group D4 consists of fourfold and twofold rotations around z, plus twofold rotations around x and y. It has four 1-D species and one 2-D species: BoxedCharacterTable@"D4", 9D
461
Symmetry Theory
D4 1 2 1 E C4 C2
2 C¢2
2 C¢¢ 2
¬ Class populations Basis functions
A1 1
1
1
1
1
A2 1
1
1
8H z L, H Iz L<
-1 -1
B1 1 -1
1
1
-1
B2 1 -1
1
-1
1
-2
0
0
E
2
0
9I x2 + y2 M, H z2 L= 9I x2 - y2 M=
8H x y L< x yz Ix :K O, K O, K O> y xz Iy
The two projection operators defined in the Symmetry` package are Proj ectET (ProjectExpressionTrace) and ProjectED (ProjectExpressionDetailed) We leap ahead here and use ProjectET just to demonstrate its power. We use it on an asymmetric function q[x,y]: Clear@qD; q@x_, y_D := 1 -x2 -y2 ã I1 + 2 x2 + 2 x3 M I36 + 28 y + 84 y2 + 12 y3 + y4 M; 2 ProjectET[_,"D4"] returns formulas for five functions, one for each species of group D4 : qProjections = Simplify@ProjectET@q@x, yD, "D4"DD; % Column Size@8D
:A1,
1
2 -y2
ã-x
:A2, 14 ã 4
I72 + 156 y2 + y4 + x4 I1 + 2 y2 M + 2 x2 I78 + 168 y2 + y4 MM>
-x2 -y2
:B1,
1
ã
:B2, 2 ã 4
:E, ã
-x2 -y2
-x2 -y2
-x2 -y2
x y Ix2 - y2 M>
Iy2 I12 + y2 M - x4 I1 + 2 y2 M + 2 x2 I-6 + y4 MM>
x y I7 y2 + x2 I7 + 6 y2 MM>
I2 y I7 + 3 y2 M + 4 x2 y I7 + 3 y2 M + x3 I36 + 84 y2 + y4 MM>
Look immediately at the contour plots :
462
Algebra
Fig.37.2 An asymmetric function, q@x, yD, is split into a five parts, each belonging to one of the species of group D4 .
Four of them are beautifully symmetric. Species E is a problem child; its irregular behavior is the reason we need that second operator ProjectED. On your own This is a good place to click back to Mulliken's species name rules in Chapter 28 (ReducibleReps), and see how they apply to these functions.
On your own (1) Add up the projections and see if their sum is the original q[x,y]. (2) Construct the parity operator SimplifyB
fn.SymmetryRules@D4D F fn
and apply it to the four 1-D projected functions. Then apply it to the 2D projection E.
463
Symmetry Theory
37.3 Symbolic derivation of the projectors 37.3.1 Strategy After seeing what projection operators do, you are ready to understand exactly why and how they work. Here is our strategy (click for reference) : 1. Start with a given, explicit function Ψ[x,y,z] and any group G for which you know the complete character table. Express Ψ symbolically as an expansion in some unknown functions u : Ψ@x, y, zD = Ú ui @x, y, zD N
(37.1)
i=1
The number N is also an unknown at this point. 2. Let T L be the transform rule for element L of group G. Apply T L to both sides of the expansion above : TL @Ψ@x, y, zDD = Ú TL Buk @x, y, zDF N
(37.2)
k=1
On the left, TL [Ψ] can be carried out using the SymmetryRules for group G, but on the expansion side the TL @uk D are only symbolic, because the u functions are unknown. 3. To make further progress we must assert that the function space spanned by the u functions is invariant to all the transforms TL . Then we can use the definition of the representation to replace the TL @uk D by suitable linear combinations of the u functions. 4. Operate so as to create, on the right side, the left side of the Great Orthogonality. Then replace it by the right side, a numerical factor times three ∆ functions. 5. Do a sum enabled by one of the ∆ functions, plus other maneuvers that bring the equation into the form of an eigenequation. The eigenfunctions are functions of pure symmetry under group G, and the eigenvalues are only 0 and 1. Therefore, the operator is a projection operator.
37.3.2 Derivation of ProjectED On the right side of Eq. 37.2 above, the summand is the left side of the rep mat formula from Chapter 25. We replace it by the right side : T L @ΨD = Ú T L @um D == Ú Ú uk Tk,m @LD N
464
m=1
N
N
m=1 k=1
(37.3)
Derivation
T L @ΨD = Ú T L @um D == Ú Ú uk Tk,m @LD N
N
m=1
N
m=1 k=1
where the u's are general basis objects that transform invariantly under the transforms of the group. But now we know about species and irreducible representations, and Tk,m @LD can be the irreducible representation matrix for {species Σ, element L} if we let the uk functions be basis functions for it. We mark this change by switching from u to b, and introducing a species index Σ : HΣL
TL AbHΣL m E = Ú bk d@ΣD
THΣL k,m @LD
(37.4)
k=1
where summation limit N has become d[Σ], the dimension of species Σ; the HΣL
THΣL k,m @LD are the matrices of rep Σ; and the basis objects bk
are now specifi-
cally basis functions for species Σ. HΣL
We will call the functions bk “ functions of pure G symmetry”. Simple examples of them may be found on the right side of the character table, but the point here is that many much more complicated functions also have pure G symmetry. Once we have the projection operator, we will be able to generate them with a single Enter command. Multiply on both sides by THΤL* p,q @LD (note the conjugation) and sum over L (all elements of the group) : HΣL
HΣL HΤL* Ú T L Abm E Tp,q @LD = Ú Ú bk h d@ΣD
h
L=1
L=1 k=1
HΤL* THΣL k,m @LD Tp,q @LD
(37.5)
These are finite sums and can be rearranged however you like : HΣL
HΣL HΤL* Ú T L Abm E Tp,q @LD = Ú bk h
d@ΣD
L=1
k=1
HΣL HΤL* Ú Tk,m @LD Tp,q @LD h
(37.6)
L=1
Click back to the Great Orthogonality and pull a copy down here. You will see that the sum over L on the right above is identical to the left side of the Great Orthogonality. Therefore (this is huge) we replace it by the right side: HΣL
HΣL HΤL* Ú T L Abm E Tp,q @LD = Ú bk h
d@ΣD
L=1
k=1
h ∆ ∆ ∆ d@ΤD Σ,Τ k,p m,q
(37.7)
Move the sum over k as far right as possible : HΣL
HΣL HΤL* Ú T L Abm E Tp,q @LD = d@ΤD ∆Σ,Τ ∆m,q Ú bk L=1 k=1 h
d@ΣD
h
∆k,p
(37.8)
Now perform the sum over k. Every summand is zero except when k = p, so HΣL
HΣL HΤL* Ú T L Abm E Tp,q @LD = d@ΤD bp L=1 h
h
∆Σ,Τ ∆m,q
(37.9) (37.3) 465
Symmetry Theory
HΣL
HΣL HΤL* Ú T L Abm E Tp,q @LD = d@ΤD bp L=1 h
h
∆Σ,Τ ∆m,q
Rearrange a bit : HΣL d@ΤD h HΣL HΤL* Ú T L Abm E Tp,q @LD = bp ∆Σ,Τ ∆m,q h L=1
(37.10)
This equation has five free indices; Σ, Τ, m, p and q. So we can turn this into an eigenequation by simply setting the free index m equal to p. It becomes an eigenequation because the same function will then appear on both sides: HΣL d@ΤD h HΣL HΤL* Ú T L Abp E Tp,q @LD = bp ∆Σ,Τ ∆p,q h L=1
(37.11)
The fog will lift a little if we make a simple symbol for the operator of this eigenequation. Letting g be a dummy operand, the operator definition is PHΤL p,q @g_D :=
d@ΤD h HΤL* Ú T L @gD Tp,q @LD h L=1
(37.12)
enabling us to write HΣL
HΣL PHΤL p,q Abp E = bp
∆Σ,Τ ∆p,q
(37.13)
HΤL If we change PHΤL p,q on the left into Pq,q the equation is really the same, because
there is still a p and a q on the left and a ∆p,q on the right. But since the two lower indices on P will now always be the same, we can write only one. So HΣL
HΣL PHΤL q Abp E = bp
∆Σ,Τ ∆p,q
(37.14)
This is the simple eigenequation we wanted. It says that whenever PHΤL q operates
on a function of pure G symmetry, it either gives the function back unchanged (if both index pairs match) or else it gives zero (if one index pair doesn't match). This is what is meant by a symmetry projection operator. This PHΤL q becomes ProjectED in the Symmetry` package . So box it up: PHΤL q @g_D :=
d@ΤD h HΤL* Ú T L @gD Tq,q @LD h L=1
(37.15)
Think about applying PHΤL to some function from a space that is spanned by all q
the functions that have pure G symmetry. This is an enormous space, containing every function that a chemist will ever be interested in. To be concrete, let the group G be D4 , as in the introductory numerical example. Then any function Y can be written as a sum of parts having pure G symmetry A
A
B
B
Y = Ψ11 + Ψ12 + Ψ11 + Ψ12 + Ψ1E + Ψ2E 466
(37.9) (37.16)
Derivation
A
A
B
B
Y = Ψ11 + Ψ12 + Ψ11 + Ψ12 + Ψ1E + Ψ2E The subscripts 1 on the A and B species are redundant because there is only one function in those cases, but we need it because it appears in the operator. The particular rep E used in the construction of P ( namely, the matrices THΤL* a,b ) requires two basis functions, and there they are, Ψ1E and Ψ2E . Now apply a particular P operator to Y; for example, PHEL 2 . except when both index pairs match
Since the eigenvalue is zero
E PHEL 2 @YD = 0 + 0 + 0 + 0 + 0 + Ψ2
(37.17)
This is what is meant by group theoretic projection. In words, operator PHEL 2 projects out from any function Y a part that has pure symmetry E,2. If Y contains no such part, then it will return zero. But “ usually”, it will not return zero. There is no limit to how complicated Y can be, and therefore no limit on how complicated Ψ2E can be. We will hold the numerical examples until after the next section. On your own Call up the syntax statement for ProjectED and read it. Click into the Symmetry` package to read it. Then use it.
37.3.3 Derivation of ProjectET But wait! There's more! If you buy all this, we will give you, absolutely FREE, a SECOND projection operator that's EVEN NEATER than the first! Start with the general projection operator, Eq. 37.15 and sum over q. We denote the summed projector by the same P, just leaving off the subscript q : HΤL*
PHΤL @g_D = Ú Pq @gD = Ú T L @gD Ú Tq,q @LD d@ΤD
HΤL
q=1
h
d@ΤD
L=1
q=1
(37.18)
HΤL* , the conjugated Do you see it ? The summing THΤL* q,q over q creates Χ
character of the matrix L. PHΤL @g_D := Ú T L @gD ΧHΤL* @LD h
L=1
(37.19)
This is called the trace projection operator, ProjectET. Its construction no longer requires a whole representation; it needs only the characters, and these can be read straight from character tables. To write its eigenequation, bring (37.16) down the general eigenequation, Eq. 37.17 , and look at it again: 467
Symmetry Theory
This is called the trace projection operator, ProjectET. Its construction no and these can be read straight from character tables. To write its eigenequation, bring down the general eigenequation, Eq. 37.17 , and look at it again: HΣL
HΣL PHΤL q Abp E = bp
∆Σ,Τ ∆p,q
( Eq. 37.17 again)
Take the case p ® q, and sum over q : HΤL
HΣL Ú Pq Abq E =
d@ΤD
HΣL
Ú bq
d@ΤD
q=1
HΣL
∆Σ,Τ = bsum ∆Σ,Τ
(37.20)
q=1
On the right, bHΣL sum belongs to species Σ, but the components are all mixed together in it. On the left, we do not have a simple sum of P operators, and we must examine it more closely. Write it out explicitly: HΤL
HΤL
HΣL
HΣL P1 AbHΣL 1 E + ¼+Pd Abd E = bsum ∆Σ,Τ
(37.21)
But you can add as many things as you like to the operands of the P's, provided they produce zero when P operates. Zero is exactly what all the other b's HΣL
produce, even when Σ = Τ, so add them in. Then each P operator acts on bsum , and the eigenequation becomes HΤL
HΤL
HΣL
HΣL
HΣL
P1 Bbsum F + ¼+Pd Bbsum F = bsum ∆Σ,Τ HΤL
Since each Pq
(37.22)
is linear HΤL
P1
HΤL
+ ¼+Pd
HΣL
AbHΣL sum E = bsum ∆Σ,Τ
(37.23) HΤL
But that operator sum is exactly what we defined as the trace operator P the eigenequation for the trace projector is HΣL PHΤL AbHΣL sum E = bsum ∆Σ,Τ
, so
(37.24)
For one-dimensional species, this is just as powerful as the detailed projector. But for multidimensional species it gives only the sum of all the component functions you would get by detailed projection. The usual approach is to use ProjectET first, giving the 1-D basis functions and all the various bHΤL sum functions. Then construct full representations repHΤL @GD needed by Proj ectED and use that operator to crack the nuts that have not yet broken.
468
ProjectET examples
37.4 Your own examples of ProjectET On your own, you can now do as many examples as you find amusing. The main bother is the contour plots of the results, so we automate that as Display Projections. in the preliminaries. To do your own example, change the urFn and the groupName below. urFn = q@x, yD; groupName = "D3"; prjs = ProjectET@urFn, groupNameD Simplify; allD3Fns = Join@88"Ur", urFn<, prjs
This is the same Ur function as before, but now the 1-D projections involve three-fold rotational symmetry. Before, under group D4 , it was four-fold. The E function is a sum of symmetries (E,1) and (E,2), which we split apart below.
469
Symmetry Theory
37.5 Your own examples of ProjectED To see ProjectED at work, you must supply all the inputs for Project ED[sumFn,rep,cmp,grp]. We assume that grp will be the same: grp = groupName D3
and that sumFnE was returned by ProjectET[urFn,grp]. Pull it up : 8spLabel, sumFnE< = prjsP3T :E,
1
2 -y2
ã-x
I-6 x6 + 3 x7 - 3 x5 I-112 - 48 y + y2 M +
18 x4 I-38 - 8 y + y2 M - 9 x y2 I-192 + 112 y2 - 16 y3 + y4 M +
64
2 x2 I-96 + 368 y + 2004 y2 + 336 y3 + 11 y4 M +
x3 I1728 + 1792 y + 4704 y2 + 288 y3 + 49 y4 M +
2 y I448 + 96 y + 368 y2 - 326 y3 + 24 y4 - y5 MM>
Its species is E, so to split it you must first make a rep of species E. Choose basis functions from the character table : BoxedCharacterTable@groupNameD D3 1 E
2
A1 1
1
1
A2 1
1
-1
E
¬ Class populations
3
9I x2 + y2 M, I z2 M=
C3 C2
2 -1
0
Basis functions 8H z L, H Iz L<
x :K O, y
x2 2
xy
-
y2 2
,K
xz O, yz
Ix > Iy
basisFns = TabulatedBases@grpDP3, 2, 1T 8x, y<
Make the rep: repE = MakeRepPoly@basisFns, grpD
470
ProjectED examples
:881, 0<, 80, 1<<, ::::-
1
::-
1
3 ,
2
2 3 ,
2
2
>, :>, :
3
1
,-
2 1 , 2
3 2
1 2
3 2
,-
2
>, :
3 2
,-
1 2
>>,
>>, 881, 0<, 80, -1<<,
>>, ::-
1
,-
2
3 2
>, :-
3
1 ,
2
2
>>>
Do the detailed projection for component 1 . The next two operations are quite slow, but they do return. Be patient. prj1 = ProjectED@sumFnE, repE, 1, grpD Simplify 1
2 -y2
ã-x
64
I-6 x6 + 3 x7 - 3 x5 I-112 + y2 M + 18 x4 I-38 + y2 M -
9 x y2 I-192 + 112 y2 + y4 M - 2 y2 I-96 + 326 y2 + y4 M +
2 x2 I-96 + 2004 y2 + 11 y4 M + x3 I1728 + 4704 y2 + 49 y4 MM
Now do the detailed projection for component 2.
prj2 = ProjectED@sumFnE, repE, 2, grpD Simplify 1 4
2 -y2
ã-x
y I56 - 9 x4 + 9 x5 + 46 y2 +
3 y4 + 9 x y4 + 2 x3 I56 + 9 y2 M + x2 I46 + 42 y2 MM
Put them all together and display the contour plots :
EFns = 88"Esum ", sumFnE<, 8"E1 ", prj1<, 8"E2 ", prj2<<; DisplayProjections@EFnsD
Make sure it all adds up: Simplify@prj1 + prj2D == sumFnE True
471
Symmetry Theory
37.6 End notes 37.6.1 The "Totally symmetric factor " message The simple incarnation of ProjectED can be very slow if it does not have a little help. Often the problem is in a totally symmetric convergence factor like ExpA-Ix2 + y2 ME. Mathematica does not simplify powers like a human would do it, and sometimes they are like molasses. The cure we hit on seems clumsy, but it is quite fast when implemented. 1) Split expr into parts with head Power, times a remainder 2) Split each Power part into a base and an exponent 3) Run TotallySymmetricQ on each base and exponent. (This is a private test that lives only in the package.) 4) If the powers are totally symmetric, project remainder and recombine. 5) If not, project the whole expression, however long it takes. If it finds a totally symmetric factor, it issues an appropriate message.
472
38. Tabulated bases for representations Preliminaries
38.1 Introduction This chapter presents a straightforward application of the material from Chapter 37 (ProjectionOperators). All the character tables in this book have a basis function for every species of every group. Here we will show how they were found- by a simple application of the projection operators to the spherical harmonic functions. Chemists use these functions a lot because they are the angular part of the wave function for the electrons of any free atom. So the basis functions in our character tables should be especially good for chemical problems.
38.2 Basis sets from harmonic functions 38.2.1 Spherical harmonics as functions of spherical angles Every spherical harmonic depends on two angles, the polar angle Θ (latitude) and the equatorial angle Φ (longitude) of the spherical coordinate system. They all have two parameters, L (the rank) and m (the component). They are best thought of in a ziggurat array: Show@labelledZigD 0, 0
s p
1, -1
1, 0
1, +1
2, -2 2, -1
2, 0
2, +1 2, +2
3, -3 3, -2 3, -1
3, 0
3, +1 3, +2 3, +3
d f
The block labels are L,m. Each layer L of the ziggurat is a rank, and the individual blocks on that layer are its components. One rank spans the functions in one shell of an atom; s, p, d, f, …, as shown. The rank integers L begin with zero at the top, and increase without limit going down. The component numW.M. Molecular Physics bers mMcClain, for rankSymmetry L beginTheory with in m= -L on the left with and Mathematica, run by integer increments473 to DOI 10.1007/b13137_38, © Springer Science+Business Media, LLC 2009 m = +L on the right, making 2L+1 components in each rank.
The blockTheory labels are L,m. Symmetry
Each layer L of the ziggurat is a rank, and the individual blocks on that layer are its components. One rank spans the functions zero at the top, and increase without limit going down. The component numbers m for rank L begin with m = -L on the left and run by integer increments to m = +L on the right, making 2L+1 components in each rank. Any spherical harmonic can be called up in Mathematica by SphericalHar monicY[L,m,Θ,Φ]. In the preliminaries we define an abbreviated notation YAng @Θ, ΦD closer to that seen in mathematics : L,m
YAng @Θ, ΦD 3,2
1
105
ã2 ä Φ
2Π
4
Cos@ΘD Sin@ΘD2
On your own Try different values of L and m above; m is legal when -L ≤ m ≤ +L. How does Mathematica deal with illegal m ? Try one.
38.2.2 Cartesian spherical harmonics Spherical to Cartesian The spherical harmonic angular variables Θ and Φ designate a unique spot on the surface of a unit sphere. But of course so do the variables x, y, and z under the constraint x2 + y2 + z2 = 1. But we must then deal with ambiguities like x2 + y2 = 1 -z2 . We will do so by a defining a standard guise for Cartesian harmonics. We need the harmonics in Cartesian form in order to extract from them the tabulated basis functions for representations. In the preliminaries we define a
function YCar @x, y, zD that converts the angular form to Cartesian and L,m
returns them in a very compact form. If you are interested, click here and read how it is done. Here are the first rank functions : :YCar @x, y, zD, YCar @x, y, zD, YCar @x, y, zD> 1,-1
:
1,0
1
3
2
2Π
Hx - ä yL,
1,+1
1
3
2
Π
z, -
1
3
2
2Π
Hx + ä yL>
The L,± m pairs are always conjugate to each other. The Cartesian harmonics look like they are functions of three independent variables x,y,z . But that is impossible, because they trace back to angular functions of only two independent angles. There can be only two independent Cartesian variables. Indeed, the spherical-to-Cartesian rules in the definition of
YCar imply x2 + y2 + z2 = 1. Thus, YCar @x, y, zD = YAng @Θ, ΦD pro474 vided that x,y,z and Θ,Φ refer to the same point on the unit sphere. L,m
L,m
L,m
The Cartesian harmonics look like they are functions of three Basic sets from harmonic functions variables x,y,z . But that is because trace back to Cartesian variables. Indeed, the spherical-to-Cartesian rules in the definition of YCar imply x2 + y2 + z2 = 1. Thus, YCar @x, y, zD = YAng @Θ, ΦD proL,m
L,m
L,m
vided that x,y,z and Θ,Φ refer to the same point on the unit sphere. On your own Verify this by numerical example. Generate two random angles in the right range, and convert them to a Cartesian point on the unit sphere. L,m
L,m
Then test whether YAng and YCar return the same number.
If you
remember the spherical-to-Cartesian formula you will not need to click here.
Standard guise for Cartesian harmonics Cartesian spherical harmonics are tougher to deal with than simple polynomials. Because of the unit sphere identity, the harmonics may appear in a number of different guises. For instance, z2 is really the same as 1 - x2 - y2 . So we must settle on a standard guise for the spherical harmonics. We take our “standard guise” to be a form in which z appears to no power higher than 1. In the preliminaries we define an operator called ToStandardGuise. It uses FixedPoint to apply z2 ® 1 - x2 - y2 repeatedly until the result stops changing. Try it on four arbitrarily chosen polynomials: ToStandardGuiseA
9x2 y5 z3 , 5 x2 y5 z2 , 6 x2 y5 z, 7 x4 y3 =E;
% Column
x2 y5 z - x4 y5 z - x2 y7 z 5 x2 y5 - 5 x4 y5 - 5 x2 y7 6 x2 y5 z 7 x4 y3
As advertised, the highest power of z in the output is 1.
475
Symmetry Theory
38.3 Example: basis functions for D6 d 38.3.1 Introduction Here, as a single example, we find a complete set of basis functions for one group. We choose D6 d because the supporting polynomial for one of its species, A2 , was particularly elusive. But as you will see, the systematic spherical harmonic method does finally provide it in the seventh rank. Here are the polynomials that are to be found : TabulatedBases@"D6d"D MatrixForm Size@8D
A1 99x2 + y2 =, 9z2 ==
A2 99x6 z - 15 x4 y2 z + 15 x2 y4 z - y6 z=, 8Iz<= B1 992 x y Ix2 - 3 y2 M I3 x2 - y2 M z==
B2 98z<, 9z3 =, 96 x5 y - 20 x3 y3 + 6 x y5 == E1 88x, y<<
E2 99x2 - y2 , 2 x y==
E3 99x3 - 3 x y2 , 3 x2 y - y3 == E4 99x2 z - y2 z, 2 x y z==
E5 98x z, y z<, 9x5 - 10 x3 y2 + 5 x y4 , 5 x4 y - 10 x2 y3 + y5 =, 8Ix, Iy<=
We will project the first few ranks explicitly. The rank 0 harmonic is just a constant, which always belongs to the totally symmetric species. But after that the first few ranks always provide very useful small polynomials.
38.3.2 Rank 0, the s shell (species A1 ) L = 0;
polys0 = TableBYCar @x, y, zD, 8m, 0, L
:
>
1 2
Π
There is only a constant, which we interpret as x2 + y2 + z2 , the constant radius of all the Cartesian harmonics. Since D6 d is an axial group, we suspect that this is the sum of two invariant polynomials. Try it : ProjectETA9x2 + y2 , z2 =, "D6d"E
476
Example: basis functions for D6 d
99A1, 9x2 + y2 , z2 ==, 8A2, 80, 0<<, 8B1, 80, 0<<, 8B2, 80, 0<<, 8E1, 80, 0<<, 8E2, 80, 0<<, 8E3, 80, 0<<, 8E4, 80, 0<<, 8E5, 80, 0<<=
We list both of these under species A1 .
38.3.3 Rank 1, the p shell (species B2 and E1 ) L = 1;
polys1 = TableBYCar @x, y, zD, 8m, 0, L
:
1
3
2
Π
z, -
1
3
2
2Π
Hx + ä yL>
The harmonic amplitudes are of no importance to us here, so we renormalize each polynomial so that its leading term has no coefficient. The operator is NeatPoly, defined in the preliminaries of this chapter. Click to see it. neatPolys1 = Map@NeatPoly, polys1D 8z, x + ä y<
We project these simplified functions under group D6 d : prj1 = ProjectET@neatPolys1, "D6d"D; Map@Flatten, %D MatrixForm Size@6D A1 A2 B1 B2 E1 E2 E3 E4 E5
0 0 0 z 0 0 0 0 0
0 0 0 0 x+äy 0 0 0 0
1. For species B2 we take the function z. 2. For species E1 we take x + ä y. But when a complex expression appears in a two-dimensional species, the real and imaginary parts span a real 2-dimensional function space invariant under all the transforms of the group. Test this: 8x, y< . SymmetryRules@"D6h"D; Short@%, 6D Size@7D
477
Symmetry Theory
:8x, y<, :
x
3 y -
2 :
x
2
3 x ,-
2
8-x, y<, :
y +
2 x
>,
2
>, :-
2
3 y -
2
y +
2
3 y +
2
3 x ,
x
3 x ,-
2
3 y -
2 y 2
3 x
2
>, :
y -
, 2
2 x
3 y +
2
>, 17,
2 3 x
y -
, 2
2
>>
2
Indeed, each transform is a linear combination of x and y. So the table entry will be {x,y}. On your own Make a representation of D6 d on the basis {x,y}, and show that it is unitary. Click here if you can't think how to do this.
38.3.4 Rank 2, the d shell (species E2 and E5 ) Do everything in one cell : L = 2;
polys2 = TableBYCar @x, y, zD, 8m, 0, L
neatPolys2 = Map@NeatPoly, polys2D; prj2 = ProjectET@neatPolys2, "D6d"D; Map@Flatten, %D MatrixForm Size@6D; A1 A2 B1 B2 E1
1 - 3 z2 0 0 0 0
0 0 0 0 0
0 0 0 0 0
E2 0
0
x2 + 2 ä x y - y2
E3 0 E4 0 E5 0
0 0 0 0 xz+äyz 0
3. In species A1 the constant 1 and the polynomial z2 project as a weighted sum, but actually the parts belong separately to A1, because constants always project into the totally symmetric species. So just the z2 part is tabulated. 4. In species E2 , the real and imaginary parts produce the pair 9x2 - y2 , 2 x y=. We retain the coefficient 2 that goes with x y. This is quite important; we will comment on this further below. 5. In species E5 we tabulate {x z,y z}.
478
Example: basis functions for D6 d
On your own Make a representation of D6 d on the basis 9x2 - y2 , x y=, (leaving off the factor of 2 from 2 x y), and show that it is not unitary.
38.3.5 Rank 3, the f shell (species E3 and E4 ) We take another step toward complete automation by removing the uninteresting zeroes from the projected results. The operator is NoZeroes ; click here to see it. L = 3;
polys3 = TableBYCar @x, y, zD, 8m, 0, L
neatPolys3 = Map@NeatPoly, polys3D; prj3 = ProjectET@neatPolys3, "D6d"D; NoZeroes@prj3D; % MatrixForm B2 :z -
5 z3 3
>
E1 9x + ä y - 5 x z2 - 5 ä y z2 =
E3 9x3 + 3 ä x2 y - 3 x y2 - ä y3 = E4 9x2 z + 2 ä x y z - y2 z=
6. In species B2 , we see z again. Clearly z3 projects separately; we use it. 7. In species E1 , we already know x + ä y, so subtracting it we are left with -5 z2 Hx - ä y L. We could have made an entry 9z2 x, z2 y=, but we elected not to. 8. From species E3 we tabulate 9x3 - 3 x y2 , 3 x2 y - y3 =. 9. From species E4 ,we tabulate 9x2 z - y2 z, 2 x y z=.
38.3.6 What about A2 and B1 ? And so it goes. We are up to rank 3 and we have nothing yet for A2 or B1. Ranks 4 and 5 will not produce them either, but finally an A2 projection appears when L = 7, and a B1 appears when L = 8. You can try them below, changing L as necessary:
479
Symmetry Theory
L = 7; H*or any other rank *L gp = "D6d"; H* or any other group *L
polys = TableBYCar @x, y, zD, 8m, 0, L
neatPolys = Map@NeatPoly, polysD; prj1 = ProjectET@neatPolys, gpD; 8prj2a, prj2b< = Transpose@prj1D; prj2c = Map@Select@ð, Hð =!= 0L &D &, prj2bD; prj3 = Transpose@8prj2a, prj2c
1 5 1 3
1 3 1
99 z5 5
-
429 z7 35
>>,
Hx + ä yL I-5 + 135 z2 - 495 z4 + 429 z6 M>>, Hx + ä yL4 z I-3 + 13 z2 M>>,
Hx + ä yL3 I3 - 66 z2 + 143 z4 M>>, Hx + ä yL2 z I15 - 110 z2 + 143 z4 M>>,
9E5, 9-Hx + ä yL5 I-1 + 13 z2 M, Hx + ä yL7 ==> 15
In the lower harmonics, each row (each species) has only one nonzero entry, i.e., each harmonic function belongs to some pure symmetry species. But higher harmonics become so complicated that they have to split into several parts. You can see an example of this in rank 7 under D6 d , above. Component 6 in this rank is Hx + ä yL6 z, but this does not appear among the projections. The real part is in A2 , but the imaginary part is in A1 .
480
End Notes
38.4 End Notes 38.4.1 Ziggurats The ziggurat is a Babylonian temple built as a series of recessed terraces. Click here for a web page on ziggurats. Click here for the earlier similar Egyptian structures.
38.4.2 Equivalence of YAng and YCar 8Α, Β< = Π 8 RandomReal@80, 1
On the unit sphere, x = Cos[Β]Sin[Α], y = Sin[Β]Sin[Α], and z = Cos[Α]. Therefore we set
8Ξ, Η, Ζ< = 8Cos@ΒD Sin@ΑD, Sin@ΒD Sin@ΑD, Cos@ΑD< 80.170708, 0.736718, 0.654298<
Pick arbitrary rank and component indices (below, 5 and 2). The acid test: JYCar @Ξ, Η, ΖD - YAng @Α, ΒDN Chop 5,2
5,2
0
So the angular and Cartesian forms return the same output.
38.4.3 Checking unitarity It's a one-liner: MakeRepPoly@8x, y<, "D6d"D; Map@UnitaryQ, %D Union
8True<
481
39. Quantum matrix elements Preliminaries
39.1 Matrix elements defined In quantum mechanics we often encounter expressions of the form * à Ψi @ΤD QBΨj @ΤDF â Τ
where Ψi and Ψj are the eigenfunctions of some Hamiltonian. Operator Q may be anything, but it is usually Hermitian. The integral is a multiple integral over the whole domain of variables Τ, which might be, for instance, {x,y,z}, each running from -¥ to +¥. Explicitly, Ù-¥ Ù-¥ Ù-¥ Ψi @x, y, zD Qx,y,z @Ψj @x, y, zDD â x â y â z +¥ +¥ +¥ *
Two shorthand notations are commonly seen; namely, Xi|Q|j\ or
Qi,j .
The latter notation brings to mind a matrix, Qi,j being the element in row i, column j. In fact, these expressions are called matrix elements. Group theory has a lot to say about matrix elements. It is especially helpful in identifying those that are zero, or nonzero matrix elements that are equal. It does not help with finding the numerical values, however. The term totally symmetric comes up a lot in this chapter. The totally symmetric species of any group is the one whose character vector is a list of 1's. All groups have a totally symmetric species; it is always given as the top row of the character table; it is the “trivial” rep. In other words, a function that belongs to the totally symmetric species is unchanged under every transform in the group.
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_39, © Springer Science+Business Media, LLC 2009
483
Symmetry Theory
39.2 The Bedrock Theorem, and its corollary 39.2.1 The theorem Here is the full formal statement, for the record. We will pull it apart into more digestible chunks below. The Bedrock Theorem, general statement
Let the functions :pU1 , ¼, pUnU > be the basis for a unitary irreducible rep of species U of group G, and let functions
:qV1 , ¼, qVnV > be the basis for a unitary irreducible rep of species V. Then
V XpU* i qj \ = 0
(39.1)
if the species are different ( U ≠ V ) or if the components are different (i ≠ j). Important comment:
If the functions :pU1 , ¼, pUnU > (or :qU1 , ¼, qUnU >) are basis functions for a rep, they must span a space that is invariant under all the transforms of the group. Click here to review the term invariant space. Specialize the general statement for functions of different species : The Bedrock Theorem for different species If function pU belongs to species U of group G, and if qnot U belongs to a different species of the same group, then XpU* qnot U \ = 0
(39.2)
This is the way most people remember the Bedrock Theorem. But the general statement (involving that invariant space stuff) becomes important when both functions belong to the same multidimensional species (a species E, or T, say). The Bedrock Theorem has an important corollary. To keep it simple, we state it below only for the two-dimensional species E :
39.2.2 The corollary 484
Statement
39.2.2 The corollary
Bedrock Corollary for species E If :pE1 , pE2 > and :qE1 , qE2 >) support the same unitary representation of the two dimensional species E, then YpE* 1
qE1 ]
=
YpE* 2
qE2 ]
(39.3) and
E E* E YpE* 1 q2 ] = Yp2 q1 ] = 0
First comment This often causes two matrix elements to have exactly the same size, even when it is not clear geometrically how symmetry is making it happen. We will do in detail the two perpendicular transition moments of benzene, which are equal by this corollary.
Fig. 39.1 Two integrands that have exactly the same integral. Can you see why, by geometrical reasoning? (No way …)
Second comment The word unitary above is important. The relative sizes of pE1 and pE2 (and of qE1 and qE2 ) are set by the fact that they support a unitary representation. To see the difficulty that non-unitarity leads to, double the second member to make
basis sets :pE1 , 2 pE2 > and :qE1 , 2 qE2 >. These will still support a common representation, but it will not be unitary. And of course the 1,1 and 2,2 matrix elements can no longer be equal, since 2,2 will be four times as large as formerly.
39.3 Example using two polynomials
485
Symmetry Theory
39.3 Example using two polynomials 39.3.1 Define two polynomials and project them Define polynomials pFn and qFn. Each one is a homogeneous polynomial plus a totally symmetric polynomial. Click to review the definition and basic properties. We use orders 5 and 7. But homogeneous polynomials of odd order (times a totally symmetric convergence factor) always integrate to zero, and this is undesirable here. So the totally symmetric polynomial is added on to keep that projection from integrating to zero. This does not affect the species E part of the projection, which is our focus below. Ix7 - 5 x6 y + 6 x5 y2 - 50 x4 y3 + 2 x3 y4 + 7 x2 y5 -
pFn@x_, y_D :=
9 x y6 + 5 y7 M + 10 Ix2 + y2 M
3
qFn@x_, y_D :=
Ix5 + 7 x4 y + 60 x3 y2 + 7 x2 y3 + 3 x y4 + y5 M - 3 Ix2 + y2 M ; 2
DisplayCPs@ 88"pFn", pFn@x, yD<, 8"qFn", qFn@x, yD<<, 3, 220D
Fig. 39.2 Contour plots of two asymmetric polynomials in x and y
We will use repE, constructed below, to do the detailed projection. repE = MakeRepPoly@8x, y<, "D3"D; % GridList Size@6D
486
Polynomial example
:
1 0
0 1
,
1 2 3
0 -1
,
1
-
2
1
3
2
2
3
1
2
2
,
2
-
2
1 0
3
-
, -
1
3
2
2
3
-
2
1 2
-
,
1 2
3 2
3
1
2
2
>
On your own The character table for D3 shows an alternative basis set for the E representation; namely, 9Ix2 - y2 M, 2 x y=. Show that the representation supported by
9Ix2 - y2 M, -2 x y=
(note the minus sign) is identical to
that supported by {x,y}. That is why we call it repE, not repExy. Sort@repED == SortAMakeRepPolyA9Ix2 - y2 M, -2 x y=, "D3"EE True
In the closed cell below, we carry out the entire projection of both the p and q polynomials, using both ProjectET and ProjectED, and then plot the projected parts.
Fig. 39.3 Complete projections of the two asymmetric polynomials, group D3
Note that pEx looks odd in x and even in y, like x itself, while pEy looks odd in y and even in x, like y itself. Similarly, for q. Check this in the formulas: 8832 pEx, 64 pEy<, 8qEx, 16 qEy<< Expand GridForm Size@9D
487
Symmetry Theory
-13 x7 + 237 x5 y2 + 289 x3 y4 - 153 x y6
559 x6 y - 1735 x4 y3 + 741 x2 y5 + 27 y7
5 x5 + 52 x3 y2 - 9 x y4
43 x4 y + 66 x2 y3 + 39 y5
Do the projected parts add up correctly?
8Expand@pFn@x, yDD == Expand@pA1 + pA2 + pEx + pEyD, Expand@qFn@x, yDD == Expand@qA1 + qA2 + qEx + qEyD< 8True, True<
39.3.2 Integrate the projected parts There is a corollary to the Bedrock Theorem that is easy to demonstrate numerically right now. To see it, all you have to do is integrate the projected parts. We define an operator integral2D containing a totally symmetric convergence factor. This is essentially a redefinition of p and q which gives them a new factor ExpA-Ix2 + y2 M 2E. This does not alter their symmetries because the new factor is totally symmetric under all point groups. Go to Help > DocumentationCenter and in the top bar type in Functions ThatRememberValuesTheyHaveFound to read about the slightly strange definition below. The strangeness is a speedup trick that was useful in developing this chapter, to avoid computing the same integral twice. Clear@integral2DD; integral2D@u_D := integral2D@uD = à
+¥
-¥
à
+¥
-¥
EvaluateAExpA-Ix2 + y2 ME uE â x â y
Two-dimensional integrals can be slow, but the following four are not too bad: Map@integral2D, 8pA1, pA2, pEx, pEy
860 Π, 0, 0, 0<
Everything except pA1, the totally symmetric part, integrated to zero. Try the same thing on the q polynomial : Map@integral2D, 8qA1, qA2, qEx, qEy
8-6 Π, 0, 0, 0<
Again, the same thing. This always happens. This is not the complete Bedrock Theorem, but this is an important consequence, and it is the way many people remember the theorem. So it is good to see it happening.
488
Polynomial example
On your own This does not mean that you never get zero when you integrate a totally symmetric function. Make a homogeneous polynomial of odd degree, project it, and use integral2D on its totally symmetric part. You will see.
39.3.3 The pair product integrals Now we are ready to test the Bedrock Theorem. Make a 4 ´4 array of the integrands, pPart ´ qPart : pqIntegrands = Outer@Times, pParts, qPartsD; Dimensions@pqIntegrandsD 84, 4<
Mathematica can do all 16 of the pqIntegrands exactly, but the first time through it takes a little while. So be patient. Integrals
qA1
qA2
qEx
qEy
pA1
-5625 Π
0
0
0
pA2
0
0
0
pEx
0
0
2385 Π
0
pEy
0
0
0
61 605 Π 128
-
303 255 Π 128
We certainly see a nice diagonality, as predicted by the Bedrock Theorem. But didn't the Bedrock Corollary say that XpEx * qEx\ = XpEy * qEy\? This is
605 Π just not true. We see XpEx*qEx\=2385Π, while XpEy*qEy\= 61128 .
Something is amiss. To quote Groucho Marx (caught cheating in Duck Soup) “This is not what it looks like… Who are you going to believe? Me, or your own eyes? ”
489
Symmetry Theory
39.3.4 A very common error Before we denounce and repudiate the Bedrock Corollary, read it again, very carefully : Bedrock Corollary for species E If :pE1 , pE2 > and :qE1 , qE2 >) support the same unitary (39.4)
representation of the two dimensional species E, then ... HEY, HOLD IT RIGHT THERE
In the numerical example, do these function pairs support the same unitary representation? Neither pair can support any representation unless it spans an invariant space. We can test that very easily. Make an invariant space based on pEx, and see if pEy pops forth as the complementary invariant partner: 8MISx, MISy< = MakeInvariantSpace@pEx, "D3"D :x7 -
237 x5 y2
-
289 x3 y4
13
x6 y -
153 x y6 ,
13
211 x4 y3 179
+
-
159 x2 y5
13 +
179
39 y7 179
>
We don't need equality, just proportionality: :
MISx
:-
MISy ,
pEx 32 , 13
pEy
> FullSimplify
64 I179 x6 - 211 x4 y2 - 159 x2 y4 + 39 y6 M
179 I559 x6 - 1735 x4 y2 + 741 x2 y4 + 27 y6 M
>
Functions MISx and pEx are indeed proportional (that is the way the invariant space operator works) but MISy and pEy are not proportional. So the pair 8pEx, pEy< does not support an invariant space, and therefore cannot support any representation at all. The Bedrock Corollary simply doesn't apply. And, as we saw by calculation, it didn't. We made this blunder to illustrate one of the most common and deeply puzzling errors in the use of group theory. The Bedrock Corollary does produce surprising equalities between matrix elements, but you have to obey all the fine print. In other words, you must actually construct the two representations and verify that they are identical and unitary. Now we will do it the right way. 490
39.3.5 Correct the error
Polynomial example
39.3.5 Correct the error What do we have to do to see the Corollary obeyed? We need two pairs of functions that “support the same unitary representation of the two-dimensional species E”. For one pair we can use {x,y}, lifted right from the D3 character table. That will be our {qEx,qEy}. For the other pair {pEx,pEy} we will use invarX and invarY, calculated just above. We know by construction that invarX and invarY support a representation, but we are not guaranteed that it is unitary. For that, they must be have the right relative scaling. This is done by the usual “balancing” procedure, automated in an End note. The BalancePolyBasis operator yields two solutions 8solnMinus, solnPlus< = BalancePolyBasis@invarX, invarY, "D3"D ::x7 -
237 x5 y2
289 x3 y4
13
179 x6 y
:x7 -
-
+
211 x4 y3
237 x5 y2
-
+
159 x2 y5 13
289 x3 y4
13 -
, 13
13
179 x6 y
153 x y6
13
13
13
+
+
153 x y6
13 211 x4 y3 13
-
- 3 y7 >, ,
13 159 x2 y5 13
+ 3 y7 >>
The two solutions differ only in relative sign. After trying both we know that solnMinus is the one we want: 8baseFnX, baseFnY< = solnMinus;
Now we can answer the big question. Do {baseFnX,baseFnY} and {x,y} support the same representation? The test is simple; make the reps and ask if they are equal: pRep = MakeRepPoly@8baseFnX, baseFnY<, "D3"D; qRep = MakeRepPoly@8x, y<, "D3"D; pRep == qRep True
Then ask if they are unitary :
Map@UnitaryQ, pRepD Union
8True<
We are on track, and ready to integrate. But look at the integrands first: 491
Symmetry Theory
x*baseFnX
y*baseFnY
Fig. 39.4 Contour plots of two polynomials that integrate to the same value.
Can you see geometrically that these integrals should be the same? Personally. I will be amazed if they are equal. Calculate them: 8integral2D@x * baseFnXD, integral2D@y * baseFnYD< 8-12 Π, -12 Π<
They are equal. I am amazed. Finally, the Bedrock Corollary is confirmed numerically. On your own We based all this on the pEx function. But all we needed from it was that it was a function of species E. We have three others: pEy, qEx, and qEy. You can go through the same thing using any of them. Try it.
39.4 Major example: benzene transition moments 39.4.1 Make the benzene orbitals Invariant function spaces usually arise in molecular physics as degenerate molecular eigenfunctions. We will demonstrate it on a famous case, the strongest electronic transition of benzene in the near ultraviolet, named A1 g ® E1 u . For this numerical demonstration we do not need accurate wave functions for benzene. They are known, but they are far too large for the small computer you are using to read this book. Instead we will use relatively simple functions that serve as an “artist's conception” of the accurate wave functions, having the same nodal structure and similarly shaped lobes. They have the great advantage that Mathematica can do their matrix element integrals exactly, in infinite precision, with computation times that are usually under a minute. 492 All the calculations may be read in the End Notes by interactive readers, but we close them up in the printed version. Here we just recap briefly what the calculations are, because they are almost like the polynomial case in Section 39.3,
For this numerical demonstration we do not need accurate wave functions for benzene. They are known, but they are far too large for the small computer you are using to read this book. Instead we will use relatively simple functions that serve as an “artist's conception” of the accurate wave functions, having same Benzenethe example
with computation times that are usually under a minute. All the calculations may be read in the End Notes by interactive readers, but we close them up in the printed version. Here we just recap briefly what the calculations are, because they are almost like the polynomial case in Section 39.3, above. Instead of postulating arbitrary polynomials, we construct linear combinations of carbon-centered atomic wave functions on a benzene framework. We show how to do this in Chapter 40, on SALC construction. We pick out the SALCs of symmetries A1 g , E1 u,x and E1 u,y , balance the two E functions, and normalize all three. Then we verify that E1 u,x and E1 u,y support the same representation that x and y do. The contour plots of these functions are
Fig. 39.5 Benzene orbitals used in the transition moment calculations E1u The detailed formulas are assigned to the symbols ΨA1g , ΨE1u x , and Ψy .
Interactive readers, bring them up and look at them. You will see that they are just sums of gaussians.
39.4.2 Compute the transition moments To verify the Bedrock corollary we need to compute four integrals: ::à
+¥
à
+¥
-¥ -¥ +¥ +¥
:à
-¥
à
-¥
IΨA1g x ΨxE1u M â x â y , à
+¥
à
+¥
-¥ -¥ +¥ +¥
IΨA1g y ΨxE1u M â x â y , à
-¥
à
-¥
IΨA1g x ΨyE1u M â x â y>, IΨA1g y ΨyE1u M â x â y>>
The ContourPlots of these integrands are very interesting:
493
Symmetry Theory
Fig. 39.6 Contour plots of the four integrands calculated below
Who would guess that those two diagonal contours have exactly the same integral? Personally, I won't believe it until I see it. So do the integrals and tabulate them. Here they are:
benzene ΨA1g x ΨA1g y
1 2
J2 +
ΨE1u x 1 ã92
0
+
3 ã32
ΨE1u y
NΠ 1 2
J2 +
0 1 ã92
+
3 ã32
NΠ
That is the Bedrock Corollary, obeyed. The function ΨA1g x ΨxE1u gives exactly the same integral as ΨA1g y ΨyE1u . This is why benzene has the same absorption coefficient for any linear polarization that vibrates in the plane of the molecule. On your own Take a polarization vector given as x Cos[Θ]+ y Sin[Θ], and prove that this is true. Remember, the rule for combining independent processes is to add probabilities. After two numerical demonstrations, one for polynomials and one for molecular orbitals, you should now be ready for the complete proof of the Bedrock Theorem and its Corollary. 494
Benzene example
After two numerical demonstrations, one for polynomials and one for molecular Theorem and its Corollary.
39.5 Proof of the Bedrock Theorem 39.5.1 Main theorem Our reasoning begins with a fairly simple Lemma : Matrix elements are invariant under point group transformations of the integrand. Xf\ = [T L @fD_
(39.5)
A point group transformation amounts to turning the contour plot of the integrand about the origin, or reflecting it in a plane that passes through the origin. But all point group transformations are unitary, so all point-to-point distances in the contour plot are preserved. This means that the shape of the contour plot does not change. If it is integrated over all space, the integral of the new function will have the same value as the integral of the old function. If you want a more formal argument, click here. If you want a numerical example, click here. [pUi , qVj _ = [IpUi M qVj _ = [KT L ApUi EO T L BqVj F_ *
*
In Chapter 25 (Representations) (click to review) we defined the representation matrix T as the solution to T L @fk D = Ú fh Th,k @LD. In the derivation there, nf
h=1
the functions fh were basis functions for a particular irreducible representation which was understood throughout the derivation. But now we assume explicitly that the functions pUi are basis functions for rep U, while the qVj are basis functions for rep V. So reluctantly we include another index on the T, to indicate its species. Also the sum limits may be different for the two species : [IpUi M qVj _ = [ â pUh TUh,i @LD *
nU
h=1
*
â qVk TVk,j @LD_ nV
k=1
Since this is true for every transform in the group, we can sum over all the elements L of the group. If g is the order of the group, this gives us g copies of the same thing on the left :
495
Symmetry Theory
g
* [IpUi M
qVj _
= â[
U â ph h=1 nU
L
TUh,i @LD
*
â qVk TVk,j @LD_ nV
k=1
Reversing the order of summation, and factoring as much as possible out of the L sum [IpUi M qVj _ = I M [ Ú Ú IpUh M qVk _ Ú TU @LD g *
nU nV
1
*
L
h=1 k=1
*
h,i
TVk,j @LD
But the L sum is just the left side of the Great Orthogonality Ú TU @LD L
*
h,i
TVk,j @LD ==
g ∆ ∆ ∆ nV U,V h,k i,j
so putting the right side in its place, canceling the g's, and rearranging [IpUi M qVj _ = *
1 nV
U â â ∆h,k [Iph M qVk _ ∆U,V ∆i,j nU nV
*
h=1 k=1
The factor ∆h,k in the sum over h ensures that each summand is zero unless h = k, so we may perform that sum explicitly: [IpUi M qVj _ = *
1 nV
U â [Ipk M qVk _ ∆U,V ∆i,j nV
*
k=1
The sum depends on the species symbols U and V, but the sum over k erases all component index dependence. Therefore we may denote it by CU,V . The Bedrock Theorem, general statement
Let the functions :pU1 , ¼, pUnU > be the basis for a unitary irreducible rep of species U of group G, and let functions
:qV1 , ¼, qVnV > be the basis for a unitary irreducible rep of
(39.6)
species V. Then
[IpUi M qVj _ = CU,V ∆U,V ∆i,j *
This says that the integral vanishes if the species are different ( U ≠ V ) or if the components are the different (i ≠ j), which was to be shown.
39.5.2 Corollary In the Bedrock Theorem, Eq. 39.6 , above, when V ® U and j ® i, we have
496
Proof
YIpUi M qUi ] = CU *
Index i appears on the left, but no longer appears on the right. We did not drop it accidentally; it was honestly used up; after setting i = j, it appears on the right only in ∆ii , and that evaluated to 1.
This equation is trying to tell us that all the integralsYIpU1 M qU1 ], YIpU2 M qU2 ], *
*
… all have the same value CU , which depends only on the species label U. It does not give a useful formula for CU , it just says that this constant exists. Bedrock Corollary If :pS1 , ¼, pSn > and 9qS1 , ¼, qSn =) support the same irreducible unitary representation of the multi-dimensional species S, then
(39.7)
YpSi qSi ] = CS *
where CS depends only on species S, and not at all on index i. Next, we make these careful, intricate statements into rules of thumb.
39.6 Integrals over functions of pure symmetry 39.6.1 Integrands of pure symmetry Look again at Fig. 39.2, showing the projected parts of a function (click here) . We are going to show formally that the integrals of all these projected parts are zero, with the possible exception of the totally symmetric part. Visually, you can see it immediately, because of the equal-but-opposite lobes that characterize functions of pure symmetry. The formal proof is based on the Bedrock Theorem, using a simple constant 1 as one of its functions. Mathematicians are careful to define “ function” so that it include constants. Try projecting a constant, using any group you like : ProjectET@1, "D6h"D
88A1g, 1<, 8A2g, 0<, 8B1g, 0<, 8B2g, 0<, 8E1g, 0<, 8E2g, 0<, 8A1u, 0<, 8A2u, 0<, 8B1u, 0<, 8B2u, 0<, 8E1u, 0<, 8E2u, 0<<
The function 1 always comes out whole as the component of total symmetry. All other species are always zero. This makes sense: no point group transform ever changes 1 to anything else, so it does indeed have total symmetry. 497
Symmetry Theory
All other species are always zero. This makes sense: no point group transform ever changes 1 to anything else, so it does indeed have total symmetry. Now rethink the Bedrock Theorem Eq. 39.6 (click back) denoting a generic species of totally symmetry as using A1 g : [Jp1 N qVj _ = CU,V ∆A1g,V ∆1,j A1g *
A1g
Now taking a case where p1
= 1, we see that [qVj _ = 0 unless V is the totally
symmetric species (in which case j can only be 1), it collapses to [qj
not totally symmetric
_=0
(39.8)
That is, pure symmetric functions other than totally symmetric functions always have symmetric lobes of opposite sign that make their integrals vanish. But
don't get too carried away. This is different from saying [qA1g _ ¹ 0, which cannot be proved because it is not true. Often it is true, but exceptions are not hard to cook up.
39.6.2 Selection rules, electronic and vibronic Now go one little step more. The projection theorem says that any function q[x,y,z] can be split into summands with pure symmetry under any group : q@x, y, zD = qA @x, y, zD + qB @x, y, zD + ¼+ qE,1 @x, y, zD + qE,2 @x, y, zD + ¼
where A is the species of total symmetry. Now integrate both sides. On the right, every integral vanishes except A. So we have shown that Ù-¥ ¼Ù-¥ q â Τ = Ù-¥ ¼Ù-¥ qA â Τ +¥
498
+¥
+¥
+¥
Application
In words, The integral of any function over all space is the same as the integral of its totally symmetric component. Or to put it another way, If a function has no totally symmetric component, its integral will vanish. This is of enormous use in quantum theory. The question is whether or not a matrix element of the form Ù Ψi* @ΤD QBΨj @ΤDF â Τ
vanishes or not. The answer is: Apply ProjectET to the integrand. If it has no totally symmetric component, the integral vanishes.
39.6.3 Laporte's rule Here is another benzene transition moment: à ΨA1g @ΤD x ΨE2g @ΤD â Τ . Is it necessarily zero, or not? If you know LaPorte's rule, you can say immediately that it is zero. In systems with an inversion center, eigenfunctions of even inversion parity are labelled g (for gerade) and those of odd parity are labelled u (for ungerade). Laporte's rule Dipole transitions of type g®u and u®g are allowed; those of type g®g and u®u are forbidden. The reason is that the dipole transition operator (x, y, or z) is a function of type u. So integrands that are either g ´ u ´ u = g or u ´ u ´ g = g do not generally integrate to zero, and are allowed. But integrands of type g ´ u ´ g = u, or of type u ´ u ´ u = u must always integrate to zero, and are forbidden.
499
Symmetry Theory
39.7 End Notes 39.7.1 Homogeneous polynomials A homogeneous polynomial is one in which the powers of each summand add to the same integer. It cannot have a constant term, because the powers of the constant term add to 0. A homogeneous polynomial of order 5 in x and y, for instance, has summands c xm yn , where m + n = 5. So either m or n must be odd. When the polynomial
(times a totally symmetric convergence factor like ã-Ix +y M ), is integrated over all space the odd-power coordinate produces zero. So odd-order polynomials always integrate to 0. 2
2
Homogeneous polynomials multiply like integers: even ´even = even, odd ´odd = even, and odd ´even = odd.
39.7.2 Balancing basis polynomials As before, in Chapter 29 (MakeUnitary), we go step by step through the balancing procedure; but this time we will automate it at the end. Start with a pair of functions known to belong to species E of group D3 , and known to span an invariant space, but not yet “ balanced” to support a unitary representation. They were projected out of pE1 using a rep based on {x,y}, so one transforms like x, the other like y: We copy the raw functions come from Subsection 39.3.4 (click back): pE1x = x7 -
237 x5 y2 13
pE1y = x6 y -
289 x3 y4
-
211 x4 y3 179
13 -
+
159 x2 y5 179
153 x y6 ; 13 +
39 y7 ; 179
Multiply one of the functions by an unknown k, and make the rep : kRep = MakeRepPoly@8pE1x, k pE1y<, "D3"D :881, 0<, 80, 1<<, ::::-
500
1 2
,-
13
3 k 358
>, :
,
1
13
3 k
, 2
179
358 3
26 k
,-
1 2
>, :-
179
3
26 k
,-
1 2
>>,
>>,
,
End Notes
881, 0<, 80, -1<<, ::::-
1
13
>, :
3 k
, 2
358
1
,-
13
2
179
3 k 358
3
179
3
1 ,
26 k
2
>>,
>>>
1 ,
26 k
>, :-
2
remainders = Map@HTranspose@ðD - Inverse@ðDL &, kRepD Flatten Union :0,
179
3
-
13
26 k
3 k
,-
179
358
3
+
13
26 k
3 k 358
>
kSoln = Solve@remaindersP2T == 0, kD ::k ® -
179 13
>, :k ®
>>
179 13
We do not know whether to use the positive or negative solution, so we pick the positive one (always the second one) arbitrarily, and make the balanced basis : 8xBasisBal, yBasisBal< = 8pE1x, k pE1y< . kSolnP2T Expand :x7 -
237 x5 y2
289 x3 y4
-
13
179 x6 y
-
13
+
153 x y6 ,
13 211 x4 y3
-
13 159 x2 y5
13
13
+ 3 y7 >
This is the end of the construction. See if it worked : repBB = MakeRepPoly@8xBasisBal, yBasisBal<, "D3"D; % GridList Size@6D :
1 0
0 1
, -
1 0
0 -1
1
3
2
2
3 2
, -
1 2
-
-
,
1
1
3
2
2
3 2
2
-
,
3
-
2
,
1 2
1
3
2
2
3
1
3
1
2
2
2
2
>
Is it unitary? Map@UnitaryQ, repBBD
8True, True, True, True, True, True<
It worked. Click into the preliminaries to read the exact text of the Balance PolyBasis operator. Test it: 501
Symmetry Theory
Test it:
8xBasisBal, yBasisBal< == BalancePolyBasis@pE1x, pE1y, "D3"D True
That was not much of a test, but at least the wheels are turning. On your own Show that repBB really is a rep of species E of group D3 . It is unitary, but is it exactly the same as repE that was used in the original projection of pE1x and pE1y ? Make that rep again, and compare: repE = MakeRepPoly@8x, y<, "D3"D; % GridList Size@6D :
1 0
-
0 1
,
1 2 3
,
,
1
-
2
1
3
2
2
3
1
2
2
-
0 -1
2
-
2
1 0
3
-
, -
1
3
2
2
3
-
2
1 2
-
,
1 2
3 2
3
1
2
2
>
Select@repBB Flatten, ð =!= 0 &D Select@repE Flatten, ð =!= 0 &D
Union
8-1, 1<
There are some sign differences. We had a 50-50 chance of that when we arbitrarily picked the sign of k inside the module. So go with the other sign, switching to Mars and Venus as our complementary pair : 8pE1, pE1< = 8xBasisBal, -yBasisBal<; MakeRepPoly@8pE1, pE1<, "D3"D == repE True
Yes, that is what it needed.
39.7.3 Balancing E1 u,x and E1 u,y BalancePolyBasis works only when MakeRepPoly works. Here we need to use MakeRepMolec. As before, multiply one basis function by an unknown k and construct the rep :
502
End Notes
kRep = MakeRepMolec@basisRaw * 81, k<, ΠsToCart, "D6h"D; % GridList Short@ð, 3D & Size@6D :
1
1 0
0 1
,
-
2 3
2 1
2k
-
1 0
1
k
2 3
2 1
-
2k
0 -1
k
-
2
-1 0
,
,
0 -1
1
k
2 3
2 1
2k
2
-1 0
,
-
1
-
2 3
,
-
2k
0 1
k 2 1
,
2
1 0
, 10,
-
0 1
, -
2 1
k
2 3
2 1
2k
2
,
1
-1 0
,
0 1
, -
2 3 2k
-
k 2 1 2
1
,
2 3 2k
-
2 3
2 1
k
2 1
2k
k
-
1
,
2
>
2
The rest is the same as for polynomials.
39.7.4 Unitary transform of an integrand In the MatrixReview we show that all unitary transforms preserve point-topoint distances (click for proof). Think of an x,y,z space with a function defined in it, and imagine further that a diamond lattice is thrown over this same space. The cells of the diamond lattice are tetrahedra. If the lattice is transformed by a unitary transformation, each tetrahedral unit cell will be rotated and/or reflected. But the lattice edge lengths will be faithfully carried over from old to new. Tetrahedra, like triangles, are completely determined by their edge lengths, so the new tetrahedra must have the same volume as the old ones. If the function value at the center of each tetrahedron is carried over from old to new at the same time, then the Riemann integral sum (tetrahedron volumes times central function values) will be invariant to the transform at every mesh size, and also in the limit of increasingly fine lattices (the integral) . Example of a unitary integrand transform A numerical demo makes it absolutely clear what we are talking about above. Take a quite arbitrary function in the x,y plane : I1 + 2 x2 + 2 x3 M I36 + 28 y + 84 y2 + 12 y3 + y4 M;
qFn@x_, y_D :=
Define an integral containing a rotationally symmetric convergence factor: int2D@u_D := à
+¥
-¥
à
+¥
-¥
ExpA-Ix2 + y2 ME u â x â y
The integrals below are a little slow, but they are exact. Be patient. 503
Symmetry Theory
The integrals below are a little slow, but they are exact. Be patient. before = int2D@qFn@x, yDD 315 Π 2
Transform #2 is rotation by a third of a turn. Its rules are Tf2 = SymmetryRules@"D3"DP2T :x ® -
x 2
-
3 y
,y®
2
3 x 2
-
y
, z ® z>
2
Subject the function to this transform and integrate it again :
after = int2D@Evaluate@qFn@x, yD . Tf2DD 315 Π 2
before == after True
As advertised, they are the same. Just for fun, look directly at the algebraic forms of the integrands of before and after (use Expand on the forms qFn[x,y] and qFn[x,y]/.Tf2). Can you see why their integrals would be the same ? (No way… )
39.7.5 Preparation of the benzene functions We can make invariant function spaces with a single hit on MakeSALCs. In the preliminaries we made up molecule "unitBenzene”. It is exactly like benzene, but scaled to have unit C-C bond length. To make the Cartesian integrals a little quicker, we want functions that depend only on x and y. So we specify an angular factor of 1, rather than the usual z : 8ΠMOs, ΠsToCartRaw< = MakeSALCs@"unitBenzene", "C", Π, 1D
We are being extremely scrupulous, so without delay we verify that these “Π ” atomic orbitals really are invariant under all the D6 h transforms. First, put them into Cartesian, abolishing their z-dependence : ΠsToCart = ΠsToCartRaw . z ® 0; AOlist = ΠsToCart . Ha_ ® b_L ® b
The invariance test is simply to carry out the definition of invariance: Transform all six orbitals under every transform in the group (making 24 ´6 transformed orbitals); then get rid of redundancies using //Flatten//Union. Since Union also sorts its output, we must also apply it to the originals, to put 504 them in the same order :
End Notes
The invariance test is simply to carry out the definition of invariance: Transformed orbitals); then get rid of redundancies using //Flatten//Union. Since Union also sorts its output, we must also apply it to the originals, to put them in the same order : HAOlist UnionL == HAOlist . SymmetryRules@"D6h"D ExpandAll Flatten UnionL True
Invariance is verified. Now we must look at the representation supported by the two functions E1 u,x and E1 u,y . It is very unlikely to be unitary as it stands, so we begin by “balancing” it.
8speciesName, basisRaw< = ΠMOsP4, 1T On your own Show that the balancing factor for this basis set is second member. Click here for help. basisE1u = basisRaw :1,
3 , applied to the
3>
Make the rep supported by this basis : repE1u = MakeRepMolec@basisE1u, ΠsToCart, "D6h"D; % GridList Short@ð, 3D & Size@6D :
1
1 0
0 1
-
2
,
3 2
3
1
2
2
, -
1
-1 0
0 -1
,
-1 0
0 1
-
1 0
0 -1
1
3
2
2
3
1
2
2
,
3
2
2
3 2
,
3
2
2
2
-1 0
3
-
2
1
-
2
-
,
1
-
2
3 2
-
0 1
1 0
, 9,
1
-
0 1
, -
2
1
,
1
3
-
2
,
1
-
3
-
2
,
3 2
2
-
,
1
3
2
2
3
-
2
1
-
2
1
2
2
3
2
2
1
3
2
2
-
2
3 2
3
1
,
1
,
>
1 2
It ought to be unitary :
Map@UnitaryQ, repE1uD Union
8True<
Click back to see that ProjectED used the {x,y} rep when it split up these E1 u functions. Our p functions are going to be 8A1 g x, A1 g y<. But since the A1 g factor always transforms into itself, this rep will be identical to the {x,y} rep. We must compare the xyRep to repE1u : 505
Symmetry Theory
Click back to see that ProjectED used the {x,y} rep when it split up these E1 u functions. Our p functions are going to be 8A1 g x, A1 g y<. But since the A1 g factor always transforms into itself, this rep will be identical to the {x,y} rep. We must compare the xyRep to repE1u : xyRep = MakeRepPoly@8x, y<, "D6h"D; xyRep == repE1u True
They had to be identical, and they are. The identity of these reps is the sine qua non of the Bedrock Corollary. Most apparent “ failures” of this corollary founder on this very rock. In the past, there was at least the excuse that rep construction was too tedious to do, just for a check. No more. Now we prepare pseudo-wave functions, taking f as a Gaussian shape around each carbon atom : Clear@fD; f@uSq_D := Exp@-3 uSqD; ΨA1g = ΠMOsP1, 2, 1T . ΠsToCart; ΨxE1u = basisE1uP1T . ΠsToCart; ΨyE1u = basisE1uP2T . ΠsToCart; Clear@fD; It is important Clear f. It is an external used by a module. ΨA1g ã-3 I1-2 x+x
2 +y2 M
1+x+x2 -
-3
ã
3
+ ã-3 I1+2 x+x
2 +y2 M
y+y2
1-x+x2 +
-3
+ã
-3 1-x+x2 -
3 y+y2
+ã
3
y+y2
-3
+ã
+
1+x+x2 +
3 y+y2
ΨxE1u 2 ã-3 I1-2 x+x
2 +y2 M
-3 1+x+x2 -
ã
- 2 ã-3 I1+2 x+x
2 +y2 M
3 y+y2
-3 1-x+x2 +
+ã
-3 1-x+x2 -
+ã
3 y+y2
3 y+y2
-3 1+x+x2 +
-ã
3 y+y2
ΨyE1u -3 1-x+x2 -
ã
3
-3 1-x+x2 +
ã
3 y+y2
3 y+y2
-3 1+x+x2 -
+ã
-3 1+x+x2 +
-ã
3 y+y2
-
3 y+y2
With these functions, you can verify the Bedrock Corollary by exact symbolic integration.
506
40. Constructing SALCs Symmetry Adapted Linear Combinations of atomic orbitals Preliminaries
40.1 What are SALCs ? The acronym SALC stands for Symmetry Adapted Linear Combinations of atomic orbitals. In small molecules, SALCs can be identical to the one-electron orbitals found by Huckel calculations, but in larger molecules they must be linearly combined to make Huckel orbitals. But their utility goes far beyond the Huckel approximation. By using SALCs as basis functions, the most sophisticated of quantum calculations can greatly reduce the size of the matrices that need to be diagonalized. The reduction of matrix size goes hand in hand with a higher level of understanding of the problem. If you are interested in understanding molecules (as opposed to just calculating their properties) you can hardly understand them at all without SALCs. The famous Schrödinger equation for one electron in an arbitrary potential can always be solved without making use of symmetry, and indeed that is how many modern calculation packages approach the problem. The central object in the finite basis method is the Hamiltonian matrix, which is extremely large in accurate solutions. It is written as ` ` ` Ù Χ1 H@Χ1 D â Τ Ù Χ1 H@Χ2 D â Τ º Ù Χ1 H@Χn D â Τ ` ` ` Ù Χ2 H@Χ1 D â Τ Ù Χ2 H@Χ2 D â Τ º Ù Χ2 H@Χn D â Τ » » º ` ` Ù Χn H@Χ1 D â Τ Ù Χn H@Χ2 D â Τ º
» ` Χn H@Χn D
where all the Χ functions are atomic orbitals centered on atoms. Those on different atoms are not orthogonal, so this matrix has few, if any, zeroes in it. In this chapter we show how to use the group theoretic projections operators to simplify this matrix before we try to solve it. We form linear combinations of the Χ functions that belong to different species of the group of the Hamiltonian (i.e., SALCs). Taking these combinations as the basis functions, those that belong to different species have a vanishing Hamiltonian integral because of The Bedrock Theorem. Click back to it for a quick refresher. The Bedrock Theorem, properly employed, produces huge regions of zeroes in the Hamiltonian matrix; in fact, with minimal cleverness it can become block diagonal. Then you can diagonalize the central blocks one by one, reducing the calculational problem enormously. But even more important, the block diagoW.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, humans. Now 507 DOI 10.1007/b13137_40, © Springer Science+Business Media, LLC 2009 in same by the Bedrock Theorem, they have Hi,k = 0 ) because they are of different species.”
The Bedrock Theorem, properly employed, produces huge regions of zeroes in Symmetry Theory the Hamiltonian matrix; in fact, with minimal cleverness it can become block calculational problem enormously. But even more important, the block diagonal structure of the problem is easily and naturally grasped by humans. Now you can say things like: “Oh, yes, of course. Even though they are in same region of space, the B1 orbitals don't interact with the B2 orbitals (i.e., by the Bedrock Theorem, they have Hi,k = 0 ) because they are of different species.”
40.2 Make SALCs, step by step 40.2.1. The input As the principal demonstration, we will make the SALCs for cyclopropenyl Cation, C3H+3 , going step by step. The neutral molecule is a radical called cyclopropenyl (15 electrons); but it is unstable in equilateral geometry. The loss of one electron settles it down into the simplest D3 h shape, an equilateral triangle. If you haven't “had” Organic, the Σ-bonded framework of the molecule is
y 2 2 z
1
1
x
3 3
Fig. 40.1 The Σ core of C3H+3 . The Π bonds are not shown.
Finding the Π bonding SALCs is the problem before us. They will be linear combinations of three pz orbitals, each on one C atom. Step through this section and watch the SALCs being constructed. Then set mol to the name of another aromatic (flat, Π-bonded) molecule and do it again. After you have grasped the process, you can Select the Section bracket to the right, and Enter. Computation will go straight down to the final answer, and a graphic will be drawn. A totally automated operator MakeSALCs, based on these operations, is described below in Subsection 40.3.1 .
40.2.2. Construct symbolic atomic orbitals 508
Make SALCs, step by step
40.2.2. Construct symbolic atomic orbitals H*Input*L mol = "cyclopropenylCation"; atomKind = "C"; orbName = Π; angFactor = z; The input has been entered above. First, look at the molecule list: molList = MoleculeToList@molD; Size@8D@Column@%DD
8C, 81, 0, 0<, 81, D3h<< :C, :- , 1
, 0>, 82<>
3
:C, :- , -
2
:H, :-1,
3 , 0>, 82<>
2 1
3
2
2
, 0>, 83<>
8H, 82, 0, 0<, 81<< :H, :-1, -
3 , 0>, 83<>
By convention, the group of the molecule is carried as the last item in the tag list of the first atom. Extract it : gp = molListP1, 3, -1T D3h
We want to make an orbital on each atom of the chosen atomKind. They are atomList = Select@molList, HðP1T == atomKindL &D :8C, 81, 0, 0<, 81, D3h<<, :C, :-
1
3 ,
2
2
, 0>, 82<>, :C, :-
1
,-
2
3 2
, 0>, 83<>>
This list will be empty if you specify an atomKind that is not in the molecule. But here, one atomic orbital is centered at each carbon atom point : atomPoints = Transpose@atomListDP2T :81, 0, 0<, :-
1
3 ,
2
2
, 0>, :-
1 2
,-
3 , 0>> 2
Construct a list of vector differences between the electron position {x,y,z} and each atomPoint : Dvecs = Map@H8x, y, z< - ðL &, atomPointsD 509
Symmetry Theory
:8-1 + x, y, z<, :
1
+ x, -
2
3 2
+ y, z>, :
1
3
+ x,
2
+ y, z>>
2
The lengths squared of the Dvecs are
args = Map@Hð.ðL &, DvecsD ExpandAll :1 - 2 x + x2 + y2 + z2 , 1 + x + x2 -
3 y + y2 + z2 , 1 + x + x2 +
3 y + y2 + z2 >
The Atomic Orbital basis set is then Clear@fD; AOs = HangFactor L * HMap@f, argsDL :z fA1 - 2 x + x2 + y2 + z2 E, z fB1 + x + x2 -
3 y + y2 + z2 F, z fB1 + x + x2 +
3 y + y2 + z2 F>
For an s orbital the angular prefactor is 1; for pz it is z; for dxy it is x y; etc. The form of f is that function which minimizes the energy expectation for the whole molecule. But we do not need to know it to determine the SALCs. For graphics purposes, f can be any centrally peaked function. The AOs need abbreviated arguments. In cyclopropenyl they are Π orbitals, so we let Π[] stand for z*f[]. The Π names we will need are orbitalSymbols = Map@orbName, Range@Length@argsDDD 8Π@1D, Π@2D, Π@3D<
It will be quite useful below to have recognition rules that turn the Cartesian formulas into Π symbols, and vice-versa. Here is the vice toSymbs = Thread@AOs ® orbitalSymbolsD :z fA1 - 2 x + x2 + y2 + z2 E ® Π@1D, z fB1 + x + x2 z fB1 + x + x2 +
3 y + y2 + z2 F ® Π@2D,
3 y + y2 + z2 F ® Π@3D>
and here is the versa toCartMOs = Thread@orbitalSymbols ® AOsD :Π@1D ® z fA1 - 2 x + x2 + y2 + z2 E, Π@2D ® z fB1 + x + x2 Π@3D ® z fB1 + x + x2 +
3 y + y2 + z2 F,
3 y + y2 + z2 F>
40.2.3. Use ProjectET to make the trace SALCs 510
Make SALCs,step by step
40.2.3. Use ProjectET to make the trace SALCs Given all the machinery we have developed, making the SALCs is a piece of cake. All the heavy lifting is done by ProjectET (the trace projector) followed, when required, by ProjectED (the detailed projector). First, we apply ProjectET to all three of the Π ligand orbitals constructed above. Why apply it to all three? This will produce a lot of redundancy. But we really do want all three; you will see why. rawTraceSALCs = ProjectET@AOs, gpD . toSymbs :8A1¢ , 80, 0, 0<<, 8A2¢ , 80, 0, 0<<,
8E¢ , 80, 0, 0<<, 8A1¢¢ , 80, 0, 0<<, Π@1D Π@2D Π@3D Π@1D Π@2D Π@3D :A2¢¢ , : + + , + + , 3 3 3 3 3 3 Π@1D Π@2D Π@3D 2 Π@1D Π@2D Π@3D + + >>, :E¢¢ , : , 3 3 3 3 3 3 Π@1D 2 Π@2D Π@3D Π@1D Π@2D 2 Π@3D + ,+ >>> 3 3 3 3 3 3
That was wonderfully easy, but it needs clean-up. Many zeroes were generated, and several projected functions are identical, or differ only by a scale factor. This is cleaned up by an operator NeatTraceSALCs defined in the preliminaries. If you want to see it work step by step, click to the End Notes. labeledTraceSALCs = NeatTraceSALCs@rawTraceSALCs, orbNameD
88A2¢¢ , 8Π@1D + Π@2D + Π@3D<<, 8E¢¢ , 8Π@1D + Π@2D - 2 Π@3D, 2 Π@1D - Π@2D - Π@3D, Π@1D - 2 Π@2D + Π@3D<<<
Three pz atomic orbitals projected into one function of species A2¢¢ and three functions of species E¢¢ . Three orbitals in and four out? That doesn't sound right (and it isn't). The multidimensional species need a detailed projection, which will reveal their redundancy and allow us to deal with it. So the next step is to separate the one-D SALCs (which are complete as they stand) from the multi-D SALCs (which need more work).
40.2.4. Separation of one-D cases from multi-D cases Separation of the one-D SALCs from the multi-D SALCs is simple for humans, but clumsy for computers. Our goal is total automation, so we do it the clumsy way. 511
Symmetry Theory
8labels, orbs< = Transpose@labeledTraceSALCsD
88A2¢¢ , E¢¢ <, 88Π@1D + Π@2D + Π@3D<, 8Π@1D + Π@2D - 2 Π@3D, 2 Π@1D - Π@2D - Π@3D, Π@1D - 2 Π@2D + Π@3D<<<
The degeneracy of a species is the first element of its character vector : speciesDims = Map@ChVec@ð, gpDP1T &, labelsD 81, 2<
Tag each species with its own degeneracy, just before the species name: orbsTagged = Transpose@8speciesDims, labels, orbs
Now we can pull out just the one-D cases :
oneDs1 = Select@orbsTagged, ðP1T == 1 &D . 8a_, b_, c__< ® 8b, c< 88A2¢¢ , 8Π@1D + Π@2D + Π@3D<<<
In simple cases this is what we want, but when there are several one-D functions that belong to the same species, it is not. We want each one-D function to have its own species label. The little operation below does exactly that: oneDs2 = Table@ spNm = oneDs1Pi, 1T; fns = oneDs1Pi, 2T; Map@8spNm, 8ð<< &, fnsD, 8i, 1, Length@oneDs1D
In the initial example, nothing happened. In other examples, you will see its usefulness. But even here the bracketing is too complicated. Fix it: oneDs = Partition@Flatten@oneDs2D, 2D . 8nm_String, fn_< ® 8nm, 8fn<< 88A2¢¢ , 8Π@1D + Π@2D + Π@3D<<<
That is the desired format for the oneD output. Turn now to the multiD projections. Pull them out by selecting on multiplicity tags greater than 1; then apply a rule that removes the tags: multiDsums = Select@orbsTagged, ðP1T > 1 &D . 8a_, b_, c__< ® 8b, c<
512
Make SALCs,step by step 88E¢¢ , 8Π@1D + Π@2D - 2 Π@3D, 2 Π@1D - Π@2D - Π@3D, Π@1D - 2 Π@2D + Π@3D<<<
As you probably know by now, the three Π combinations above, all of type E¢¢ , belong to a 2-D function space. A basis set for it will be found by ProjectED.
40.2.5. Use ProjectED to make the detailed SALCs Graphics uses redAtoms and the CP function
The next command, PrjMultiD, finishes the job. It doesn't do any real work; it is just an administrator. It is fairly complicated because it must deal with so many cases. Its operand multiDsums can be empty, or it can contain one or several species, and each species can contain one or several sums. Beyond that, it has to call MakeRepPoly to construct an entire representation for use by ProjectED. Finally, it removes redundancies and zeroes, and massages the result into the desired output form, {spName,{orthogonalSALCs}}. Click here to see PrjMultiD developed step by step. Click here to read the final module. Now watch it work: multiDs = PrjMultiD@multiDsums, toCartMOs, gpD
Using E¢¢ basis 8x z, y z<
888E¢¢ , 82 Π@1D - Π@2D - Π@3D, Π@2D - Π@3D<<<<
The three cyclopropenyl E¢¢ orbital sums reported by ProjectET were redundant; they were spanned by the two orthogonal orbitals you see above. Finally, we join all the results together, stripping the extra outer brackets from E¢¢ : allSALCs = Join@oneDs, multiDsP1TD
88A2¢¢ , 8Π@1D + Π@2D + Π@3D<<, 8E¢¢ , 82 Π@1D - Π@2D - Π@3D, Π@2D - Π@3D<<<
That is the desired final bracketing, and the SALC problem is now solved. All that remains is the graphics. Automated graphics never look good in every case, but we offer a first rough draft, fairly satisfactory for flat planar molecules. For other cases you will want to take charge yourself. The red dots are the atoms of the atomKind you asked for; black dots are other atoms in the molecule.
513
Symmetry Theory
A2¢¢
E ¢¢
E ¢¢
Fig. 40.2 The red dots are C atoms; the gray dots are H. The Π orbitals are centered only on C atoms.
You can change the input lines way at the top and rerun with other molecules. Or, you can go on to the total automation section below, and do other cases with one click. We don't know of any molecule for which this algorithm fails. If you find one, let us know. On your own Try the molecules {"cyclopropenylCation","benzene", "naphthaleneCatoms","cyclobutadiene","ethylene", "octaComplex","PCl5"}
40.3 Automation 40.3.1. The complete MakeSALCs operator In the preliminaries we define an operator MakeSALCs[mol,atomKind,orbName,angFactor] which makes the SALCs using the procedure of Section 40.2, above. Try it out on a non-trivial example: SALCs@UF9 D = MakeSALCs@"UF9", "F", Σ, 1D;
The group is D3h
Using E¢ basis 8x, y<
Using E¢¢ basis 8x z, y z< The output has four parts: (1) the molecule name, (2) the atom kind, (3) a SALCs list, and (4) a set of rules for transforming to Cartesian. Humans are 514 mainly interested in part 3; look at it:
Automation
The output has four parts: (1) the molecule name, (2) the atom kind, (3) a SALCs list, and (4) a set of rules for transforming to Cartesian. Humans are mainly interested in part 3; look at it: SALCs@UF9 DP3T; Column@%D Size@8D
8A1¢ , 8Σ@1D + Σ@2D + Σ@3D + Σ@4D + Σ@5D + Σ@6D<< 8A1¢ , 8Σ@7D + Σ@8D + Σ@9D<< 8A2¢¢ , 8Σ@1D + Σ@2D + Σ@3D - Σ@4D - Σ@5D - Σ@6D<< 8E¢ , 82 Σ@1D - Σ@2D - Σ@3D + 2 Σ@4D - Σ@5D - Σ@6D, 2 Σ@7D - Σ@8D - Σ@9D<< 8E¢ , 8Σ@2D - Σ@3D + Σ@5D - Σ@6D, Σ@8D - Σ@9D<< 8E¢¢ , 82 Σ@1D - Σ@2D - Σ@3D - 2 Σ@4D + Σ@5D + Σ@6D, Σ@2D - Σ@3D - Σ@5D + Σ@6D<<
Each species name is bracketed with a SALC list of appropriate length (the detailed projections from one trace projection). If a species has more than one SALC set, each set has a separate entry. Above, there are two 1-D SALCs of species A1¢ , one of species A2¢¢ , two 2-D SALC pairs for E¢ , and one pair for E¢¢ . Parts 1, 2, and 4 of the output are used mainly by graphics operators; but look if you want, at SALCs@UF9 DP1T, … P2T, and ¼P4T.
40.3.2. Automated two-dimensional graphics
Make the 2D eyeGuide The first job is to make a standard backdrop for the SALC graphics. This is done by the operator RedAtomsXY , which makes a 2D projection of the molecule by removing the z coordinate of all atoms, rendering the SALC centers in red, all other atoms in grey. It will work on any tabulated molecule: eyeGuideBz = RedAtomsXY@"benzene", "C"D; Show@Graphics@eyeGuideBzD, ImageSize ® 100, PlotRange ® All, AspectRatio ® AutomaticD
Fig. 40.3 The eye guide for benzene. Red is C, gray is H.
To see a step-by-step construction of RedAtomsXY, click here. The z-axis view, as above, is nearly always what you want for planar molecules. If you are doing one that needs a different view, click here. 515
Symmetry Theory
To see a step-by-step construction of RedAtomsXY, click here. The z-axis doing one that needs a different view, click here. The second job is to make a graphics cartouche of the ContourPlot of the desired SALC. We will make the graphics using SALCfigs2D. To see that operator constructed step by step, click here. Do the contour plots of the SALC functions Two-dimensional graphics are easier than three-dimensional graphics, so we do them first. 2D is appropriate for all planar molecules. We have defined some semi-automatic graphics operators that produce a decent first draft of two-dimensional SALC graphics. They were used above in the step-by-step construction of the SALCs of C3H+3 . Now we discuss how to use them in general, taking benzene as the example. First, run MakeSALCs : SALCs@C6H6D = MakeSALCs@"benzene", "C", Π, 1D;
The group is D6h Using E2g basis :
1
Ix2 - y2 M, x y>
Using E1u basis 8x, y< 2
Check the important part of the output: SALCs@C6H6DP3T; Size@7D@Column@%DD
8A1g, 8B2u, 8E2g, 8E1u,
8Π@1D + Π@2D + Π@3D + Π@4D + Π@5D + Π@6D<< 8Π@1D - Π@2D + Π@3D - Π@4D + Π@5D - Π@6D<< 82 Π@1D - Π@2D - Π@3D + 2 Π@4D - Π@5D - Π@6D, Π@2D - Π@3D + Π@5D - Π@6D<< 82 Π@1D + Π@2D - Π@3D - 2 Π@4D - Π@5D + Π@6D, Π@2D + Π@3D - Π@5D - Π@6D<<
The SALCgraphic2D operator has been written to make graphics of the output above. We call it, suppressing the output with a semicolon. The graphics are reasonably nice looking, but they are not in energy order. It takes a human to count nodes and order them correctly, as in the GraphicsColumn operator: grTbl = Table@SALCgraphic2D@SALCs@C6H6D, iD, 8i, 1, 4
516
Automation
Fig. 40.4 Benzene SALCs in energy order. Each higher figure has one more node.
40.3.3. Semi-automated three-dimensional graphics
Make a 3D eyeGuide for UF9 Here is the idiosyncratic hand work. We must construct a framework to help the eye to see the structure of UF9 in three dimensions. Six of the F atoms are at the corners of a vertical triangular biprism; the other three are staggered in the equatorial plane. The eyeGuideUF9 is made in the closed cell below. Open it to see the ghastly details.
517
Symmetry Theory
Fig. 40.5 An eyeguide for the SALCs of UF9
The red lines help you to see how the larger middle triangle pokes out through the central prism. The U atom (not shown) is in the center of the red triangle. the F atoms are at the corners of the three triangles. The bond lengths are adjusted so that the nine U-F distances are equal (nearly true in nature). Raw materials: SALCs@UF9 D Three dimensional graphics can also be automated, except for the eyeGuide, which must be made by hand for each molecule. But the rest will run without too much individual attention. Make sure that MakeSALCs has been run on UF9 : Length@SALCs@UF9 DP3TD 6
If this does not return a 6, click back and construct the SALCs@UF9 D. The command that produces the 3D graphics is SALCgraphic3D[MakeSALCsOutput,imSz,rowNbr, D] where MakeSALCsOutput is the entire output of MakeSALCs, imSz goes into ImageSize ® imSz, rowNbr is the row of MakeSALCsOutput to be used, and D goes into PlotRange®{{-D,D},{-D,D},{-D, D}}. The default for imSz is {100,100}, the default for D is 3.
518
Automation
tblUF9 = Table@SALCgraphic3D@ SALCs@UF9 D, 860, 60<, i, 3.5D, 8i, 1, 6
A¢1
A¢1 ,
,
E¢
A¢¢2
E¢
,
E¢
,
E¢
E¢¢ ,
E¢¢
>
Fig. 40.6 The SALCs of UF9 . Blue and red dots indicate the algebraic sign of the atomic orbital; size indicates amplitude. No dot means 0 coefficient.
40.4 End notes These End notes are quite lengthy and detailed, and may be read from the CD that accompanies the book.
519
41. Hybrid orbitals Preliminaries
41.1 Hybrid orbitals in general The tetrahedral nature of carbon bonding was worked out by pre-quantum chemists who had little more knowledge of atoms than Plato did. They reasoned like this: CH2Cl2 has only one isomer, not two. Therefore it cannot be square planar, but it can be tetrahedral. Think about it. It is not proof, but it makes the tetrahedral structure look plausible. Look it up in your old organic book. However, the atom orbitals first worked out by Schrödinger in 1926 showed no tetrahedral proclivities. It was Linus Pauling (1931) who first combined them to make directed valence bonds. Starting with Schrodinger's atomic orbitals, he produced all of the common bonding geometries worked out by organic chemists in over a century of empirical investigations. After this, it was hard to doubt that quantum physics was going to explain chemistry. Today a qualitative description of Pauling's results is presented in freshman chemistry, or even in high school, under the name of hybrid orbitals. Here is a typical presentation. First you see the four bonding orbitals of carbon, the Schrödinger orbitals of shell 2; a 2s and three perpendicular 2p's .
Fig. 41.1 Schrödinger's bonding orbitals of carbon.
(We plot them with holes so you can see inside. Note the inner and outer W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_41, © Springer Science+Business Media, LLC 2009
521
Symmetry Theory
surfaces of 2s. The two lobes of the 2p orbitals have opposite signs, not indicated.) Then there is a magic arrow with the word hybridization written over it, and then you see The closed graphics cell below is NOT Evaluatable
Fig. 41.2 Hybridized bonding orbitals of carbon, directed to the corners of a tetrahedron. The two lobes have opposite signs, not indicated.
Or often, you see only one of these “mushroom” orbitals. It is then said that the cap of the mushroom contains the major electron density that lets it bond tetrahedrally with other atoms. It is an enduring surprise that linear combinations of the four functions of Fig. 41.1 can produce the four tetrahedrally directed functions of Fig. 41.2. Our purpose in this chapter is to finally give you a thorough, complete understanding of just what hybridization really is, and how Pauling found it.
41.2 Pauling's hybridization strategy We will stick to the tetrahedral example, the most famous. We seek four linear combinations of the carbon orbitals 2s, 2px , 2py , 2pz skewered on the four diagonals of a cube, and therefore pointing to the four apices of a tetrahedron. Each must be cylindrically symmetric about its own diagonal, and they must be identical, except for orientation.
522
Pauling's strategy
On your own You should be able to follow this construction method to make any other hybrids your want; for instance, the sp2 hybrids of three-fold symmetry involved in the bonding of flat aromatic hydrocarbons. Or the sp hybrids of two-fold symmetry that make the bonds of linear acetylene chains. And of course there are many metal-based hybrids involved in coordination compounds. They all yield to the same method. However, the method of 41.3 is didactic, not practical. Wait until you have read the quick and easy method of Section 41.4 before you try your own hybrids. Each orbital will belong to group T; that is, the transforms of group T only swap them around from one tetrahedral apex to another. The problem is to find 16 coefficients am,n that produce the desired geometry. (If you set up a chemically impossible geometry, you will not be able to find solutions. Pauling was lucky that pre-quantum organic chemistry was exactly right about the geometries that were possible.) So all he had to do was find the a numbers in hybrid1 hybrid2 hybrid3
hybrid4
a11 a21 a31 a41
a12 a22 a32 a42
a13 a23 a33 a43
2s a14 2px a24 . 2py a34 a44 2pz
(41.1)
Pauling's stroke of genius was to realize that the a coefficients do not depend on the exact shape of the orbitals. All that is required of the functions 82s, 2px , 2py , 2pz < is that they transform , respectively, like a sphere, and like the x-axis, y-axis and z-axis. All that is required of the functions 8hybrid1 , ¼, hybrid4 < is that they be cylindrically symmetric around the cube diagonals. You can use a mock 2s function, as long as it belongs to the totally symmetric species A1 of group T; along with a mock 2px of species T and component x; etc. for 2py and 2pz . The procedure is to cook up some mock hybrids that have the desired symmetry properties, project them to get mock orbitals of species 8A1 , Tx , Ty , Tz <, and then put them into the inverse of Eq. 41.1, namely mock2s mock2px mock2py mock2pz
b11 b21 b31 b41
b12 b22 b32 b42
b13 b23 b33 b43
mockHybrid1 b14 mockHybrid2 b24 . mockHybrid3 b34 b44 mockHybrid4
(41.2)
523
Symmetry Theory
mock2s mock2px mock2py mock2pz
b11 b21 b31 b41
b12 b22 b32 b42
b13 b23 b33 b43
mockHybrid1 b14 mockHybrid2 b24 . mockHybrid3 b34 b44 mockHybrid4
in which bMat becomes the only unknown. Solve for it (using MatrixOfCo efficients). Its inverse is then the desired aMat. Take this aMat back to Eq. 41.1 and put in good carbon orbitals. Eq. 41.1 will then return good tetrahedral hybrid orbitals on the carbon atom, ready to make methane. In the next section we carry this out literally; then in the last section we will show a shortcut that uses the MakeSALCs operator of Chapter 40 (ConstructingSALCs).
41.3 Implement Pauling's strategy 41.3.1 Make the mockHybrids We need a symbolic bondFn that depends on electron position {x,y,z} through the distance from two fixed points, the carbon nucleus and a ligand nucleus (like the H atom in methane). Put the four tetrahedral vertices at rps3D = 881, 1, 1<, 8-1, -1, 1<, 81, -1, -1<, 8-1, 1, -1<<; The vectors from each vertex to the point {x,y,z} are vecs = Map@8x, y, z< - ð &, rps3DD
88-1 + x, -1 + y, -1 + z<, 81 + x, 1 + y, -1 + z<, 8-1 + x, 1 + y, 1 + z<, 81 + x, -1 + y, 1 + z<<
and the squared lengths of these vectors are
rSqList = Map@ð.ð &, vecsD ExpandAll
93 - 2 x + x2 - 2 y + y2 - 2 z + z2 , 3 + 2 x + x2 + 2 y + y2 - 2 z + z2 ,
3 - 2 x + x2 + 2 y + y2 + 2 z + z2 , 3 + 2 x + x2 - 2 y + y2 + 2 z + z2 =
Put the head Φ on these square distances to make them into mock tetrahedral orbitals : ΦList = Map@Φ, rSqListD
9ΦA3 - 2 x + x2 - 2 y + y2 - 2 z + z2 E, ΦA3 + 2 x + x2 + 2 y + y2 - 2 z + z2 E, ,
524
(41.2)
Implementation ΦA3 - 2 x + x2 + 2 y + y2 + 2 z + z2 E,
ΦA3 + 2 x + x2 - 2 y + y2 + 2 z + z2 E=
We want to refer to these four function very briefly as Φ[1] through Φ[4]: mockHybrids = 8Φ@1D, Φ@2D, Φ@3D, Φ@4D<; CartesianToΦ = Thread@ΦList ® mockHybridsD 9ΦA3 - 2 x + x2 - 2 y + y2 - 2 z + z2 E ® Φ@1D, ΦA3 + 2 x + x2 + 2 y + y2 - 2 z + z2 E ® Φ@2D, ΦA3 - 2 x + x2 + 2 y + y2 + 2 z + z2 E ® Φ@3D,
ΦA3 + 2 x + x2 - 2 y + y2 + 2 z + z2 E ® Φ@4D=
and the reverse transform is ΦToCartesian = Map@Reverse, CartesianToΦD 9Φ@1D ® ΦA3 - 2 x + x2 - 2 y + y2 - 2 z + z2 E, Φ@2D ® ΦA3 + 2 x + x2 + 2 y + y2 - 2 z + z2 E, Φ@3D ® ΦA3 - 2 x + x2 + 2 y + y2 + 2 z + z2 E,
Φ@4D ® ΦA3 + 2 x + x2 - 2 y + y2 + 2 z + z2 E=
41.3.2 Visual check of mockHybrid symmetry We now make a visual check that we have done what we intended. Purely for graphic purposes, we define a very rough embodiment of the bond function that does about what a chemist thinks it ought to do: it puts electron density between the atoms. Each point in space is at distance
x2 + y2 + z2 from the
carbon nucleus and at distance rSq@iD from ligand nucleus i. Consider an ellipsoidal shell with one focus at the carbon atom and the other on one of the ligand atoms. Everywhere on this shell, the sum of these two distances is a constant. Therefore we can define an elliptical mock bonding function as -
ellipticalBond@rSq_D := ã
x2 +y2 +z2 +
rSq
The decaying exponential puts maximum density right between the foci. The closed graphics cell below is NOT Evaluatable
525
Symmetry Theory
Fig. 41.3 The mock hybrids are four tetrahedrally oriented ellipsoids, as desired.
41.3.3 The trace projector, ProjectET Now we are ready to extract the really important information. What are the symmetry species of the mock hybrids that we have so painfully created? prjRaw = ExpandAll@ProjectET@ΦList, "T"DD . CartesianToΦ; prjΦList = NeatProjection@prjRaw, ΦD 88A1, 8Φ@1D + Φ@2D + Φ@3D + Φ@4D<<, 8T, 8Φ@1D + Φ@2D + Φ@3D - 3 Φ@4D, 3 Φ@1D - Φ@2D - Φ@3D - Φ@4D, Φ@1D + Φ@2D - 3 Φ@3D + Φ@4D, Φ@1D - 3 Φ@2D + Φ@3D + Φ@4D<<<
That is the answer: In group T, four tetrahedrally pointed functions are spanned by one function of species A1 and three functions of species T. For future use, we give these functions names : mockA1g = prjΦListP1, 2, 1T Φ@1D + Φ@2D + Φ@3D + Φ@4D
mockOrbitalsT = prjΦListP2, 2T
526
Implementation 8Φ@1D + Φ@2D + Φ@3D - 3 Φ@4D, 3 Φ@1D - Φ@2D - Φ@3D - Φ@4D, Φ@1D + Φ@2D - 3 Φ@3D + Φ@4D, Φ@1D - 3 Φ@2D + Φ@3D + Φ@4D<
There you see four functions that all live together in the same three-dimensional function space. Clearly, we need to find three nice orthogonal basis functions for that space. That is what the detailed projector is for.
41.3.4 The detailed projector, ProjectED There are four T functions, but we rather suspect that only three of them are linearly independent. The detailed projection ProjectED will tell us. We want the projected mockHybrids to transform like x, y, and z, just as Schrödinger's 2p functions do. So in ProjectED we will specify a representation of group T made with basis functions {x,y,z} : Trep = MakeRepPoly@8x, y, z<, "T"D; % MatrixList Size@6D 1 0 0 : 0 1 0 0 0 1
,
0 0 1 -1 0 0 0 -1 0
0 1 0 0 0 1 1 0 0
,
,
0 0 -1 -1 0 0 0 1 0
0 -1 0 0 0 1 -1 0 0
,
,
0 0 1 1 0 0 0 1 0
0 -1 0 0 0 -1 1 0 0
,
,
1 0 0 0 -1 0 0 0 -1
0 1 0 0 0 -1 -1 0 0
,
,
-1 0 0 0 1 0 0 0 -1
0 0 -1 1 0 0 0 -1 0
,
,
-1 0 0 0 -1 0 0 0 1
>
We have three detailed projections to do, one for each diagonal element. Turn the Φ symbols into concrete functions x, y, z; project them, then turn the projections back into Φ symbols : ΦFnsOfxyz = mockOrbitalsT . ΦToCartesian; prjsRaw = ProjectED@ΦFnsOfxyz, Trep, 1, "T"D; prjs = prjsRaw . CartesianToΦ 8Φ@1D - Φ@2D + Φ@3D - Φ@4D, Φ@1D - Φ@2D + Φ@3D - Φ@4D, -Φ@1D + Φ@2D - Φ@3D + Φ@4D, Φ@1D - Φ@2D + Φ@3D - Φ@4D<
The four projected functions look like sign variations on only one function. So use MOtoStandardForm to put them all in the same format, then throw a Union around them to get rid of redundancies : mockTx = HMap@MOtoStandardForm@ð, ΦD &, prjsD UnionLP1T Φ@1D - Φ@2D + Φ@3D - Φ@4D
Indeed, they were all the same function. To do the others the same way, make this procedure into a little Module named ΦProjection: ΦProjection@xpr_, n_D := Module@8xpr1, xpr2, xpr3<, xpr1 = ProjectED@xpr, Trep, n, "T"D; ; 527
Symmetry Theory
xpr2 = xpr1 . CartesianToΦ; xpr3 = Map@MOtoStandardForm@ð, ΦD &, xpr2D; xpr3 Union D Remember, when using a 3 ´3 representation (like Trep) to implement the detailed projection, you can do it with any one of the three diagonal elements, using n = 1, 2, or 3. So to see everything the ΦProjection can do to ΦFnsOfxyz, we Map as follows: 8mockTx, mockTy, mockTz< = Map@ΦProjection@ΦFnsOfxyz, ðD &, 81, 2, 3
88Φ@1D - Φ@2D + Φ@3D - Φ@4D<, 8Φ@1D - Φ@2D - Φ@3D + Φ@4D<, 8Φ@1D + Φ@2D - Φ@3D - Φ@4D<<
There. It gave us three different functions spanning the four functions in the list ΦFnsOfxyz. Put the trace projection of species A1g with them (we called it mockA1g), and //Sort//Reverse them : mockAOs = 8mockA1g, mockTx, mockTy, mockTz< Flatten Sort Reverse
8Φ@1D + Φ@2D + Φ@3D + Φ@4D, Φ@1D - Φ@2D - Φ@3D + Φ@4D, Φ@1D - Φ@2D + Φ@3D - Φ@4D, Φ@1D + Φ@2D - Φ@3D - Φ@4D<
That is the complete projection of the mockHybrids under group T. As you see, the nature of the Φ functions does not matter, as long as their symmetry is tetrahedral. We used the ridiculous elliptical functions we cooked up, but they could have been the most elaborately accurate functions known to quantum chemistry. Whichever, the hybrid linear combinations are the same.
41.3.5 Look at the mockAOs This is a purely academic exercise; don't take it too seriously. We wonder, out of idle curiosity, what do the mock atomic orbitals look like? If you perform mockAOs/.ΦToCartesian you have them algebraically, so it is not much trouble to do the graphics:
528
Implementation
Fig. 41.4 These mock atomic orbitals, when hybridized, give the tetrahedrally directed mock hybrids of Fig. 41.3. Interactive readers can rotate these figures around with the mouse.
They are weird, unchemical shapes. They are not even centered on the carbon atom. But the point is, each belongs to the proper species of the tetrahedral group. And it is nice to see that they are related squarely to the axes (like the functions 2px , etc.). When linearly combined, they produce four tetrahedrally pointed ellipsoids (also weird and unchemical). So when we make the same linear combinations of Schrödinger's carbon orbitals of the same species, we will get chemically meaningful hybrid orbitals pointing in tetrahedral geometry.
41.4 The SALC shortcut There is another way to get the mockOrbitals in just a few lines. Of course, they are pretty sophisticated lines, but we already have the operators for them. Just watch this, and then we will talk: Clearf, Φ; allSALCstuff MakeSALCs"methane", "H", Σ, 1
529
Symmetry Theory
The group is Td
Using T2 basis 8x, y, z<
:methane, H, 88A1, 8Σ@1D + Σ@2D + Σ@3D + Σ@4D<<,
8T2, 8Σ@1D - Σ@2D - Σ@3D + Σ@4D, Σ@1D - Σ@2D + Σ@3D - Σ@4D, Σ@1D + Σ@2D - Σ@3D - Σ@4D<<<, 118 579 107 6287 x 6287 y 6287 z :Σ@1D ® fB + x2 + y2 + z2 F, 100 000 000 5000 5000 5000 118 579 107 6287 x 6287 y 6287 z Σ@2D ® fB + + x2 + + y2 + z2 F, 100 000 000 5000 5000 5000 118 579 107 6287 x 6287 y 6287 z Σ@3D ® fB + + x2 + y2 + + z2 F, 100 000 000 5000 5000 5000 Σ@4D ® 118 579 107 6287 x 6287 y 6287 z fB + x2 + + y2 + + z2 F>> 100 000 000 5000 5000 5000
methaneSALCs = allSALCstuffP3T
88A1, 8Σ@1D + Σ@2D + Σ@3D + Σ@4D<<, 8T2, 8Σ@1D - Σ@2D - Σ@3D + Σ@4D, Σ@1D - Σ@2D + Σ@3D - Σ@4D, Σ@1D + Σ@2D - Σ@3D - Σ@4D<<<
Strip out the species information, and //Sort//Reverse them : bareSALCs = Transpose@methaneSALCsDP2T Flatten Sort Reverse 8Σ@1D + Σ@2D + Σ@3D + Σ@4D, Σ@1D - Σ@2D - Σ@3D + Σ@4D, Σ@1D - Σ@2D + Σ@3D - Σ@4D, Σ@1D + Σ@2D - Σ@3D - Σ@4D<
Compare these with the mockOrbitals at the end of Section 41.3, above mockAOs == bareSALCs
8Φ@1D + Φ@2D + Φ@3D + Φ@4D, Φ@1D - Φ@2D - Φ@3D + Φ@4D, Φ@1D - Φ@2D + Φ@3D - Φ@4D, Φ@1D + Φ@2D - Φ@3D - Φ@4D< 8Σ@1D + Σ@2D + Σ@3D + Σ@4D, Σ@1D - Σ@2D - Σ@3D + Σ@4D, Σ@1D - Σ@2D + Σ@3D - Σ@4D, Σ@1D + Σ@2D - Σ@3D - Σ@4D<
They are exactly the same. Furthermore, MakeSALCs gave us the symmetry information that we need. The group is Td , the first SALC belongs to the totally symmetric species A1 and the second belongs to T2 , projected using basis x, y, z.
530
The SALC strategy
The mockAOs were analyzed in group T, and here MakeSALCs used Td , the full symmetry of methane. But don't worry; T is a subgroup of Td , and the species names are in one-to- one correspondence. Why are the bareSALCs identical to the mockAOs? Is it always so easy? Well, yes, it is. As we said when we made up those ellipsoidal mock-hybrids, their shape does not matter; only their symmetry. We can consider the four Hbased SALCs for the methane molecule to be carbon hybrids made of weird, unphysical atomic orbitals. (So weird that they are not even centered on carbon, but even that does not matter. Symmetry is all.) All you have to know now is that the 2s carbon orbital belongs to species A1 in Td , and the three orbitals {2 px , 2 py , 2 pz } belong to species T2 (because their angular factors {x,y,z} belong). So extract the matrix of coefficients bMat from the SALCs Φ@1D + Φ@2D + Φ@3D + Φ@4D Φ@1D - Φ@2D - Φ@3D + Φ@4D Φ@1D - Φ@2D + Φ@3D - Φ@4D Φ@1D + Φ@2D - Φ@3D - Φ@4D
mock C orbitals
b11 b21 b31 b41
b12 b22 b32 b42
b13 b23 b33 b43
b14 Φ@1D b24 Φ@2D . b34 Φ@3D Φ@4D b44
(41.3)
mock hybrids
Invert bMat, and left multiply by the inverse. Replace the mockCorbitals with realCorbitals, and there you have the real sp3 hybrids : b11 b21 b31 b41
b12 b22 b32 b42
b13 b23 b33 b43
b14 b24 b34 b44
-1
Φ@2 sD Φ@2 pxD . Φ@2 pyD Φ@2 pzD
real C orbitals
Ψ@AD Ψ@BD Ψ@CD Ψ@DD
(41.4)
real sp3 hybrids
It is all quite easy:
vars = Map@Variables, mockAOsD Flatten Union 8Φ@1D, Φ@2D, Φ@3D, Φ@4D<
bMat = MatrixOfCoefficients@mockAOs, varsD; % GridForm 1 1 1 1
1 -1 -1 1
1 -1 1 -1
1 1 -1 -1
bInv = 4 Inverse@bMatD; % GridForm
531
Symmetry Theory
1 1 1 1
1 -1 -1 1
1 -1 1 -1
1 1 -1 -1
Now make the hybrids symbolically, and put them in standard form: sp3hybridsRaw = bInv.8Φ@2 sD, Φ@2 pxD, Φ@2 pyD, Φ@2 pzD<; sp3hybrids = Map@MOtoStandardForm@ð, ΦD &, sp3hybridsRawD 8Φ@2 pxD + Φ@2 pyD + Φ@2 pzD + Φ@2 sD, Φ@2 pxD + Φ@2 pyD - Φ@2 pzD - Φ@2 sD, Φ@2 pxD - Φ@2 pyD + Φ@2 pzD - Φ@2 sD, Φ@2 pxD - Φ@2 pyD - Φ@2 pzD + Φ@2 sD<
Wait just a minute. How did we know what order to use for the real orbitals Φ? What if we used a different order? Make some alternate hybrids, using a different order for the carbon orbitals; then put them in standard form also : hybridsAlt = bInv.8Φ@2 pyD, Φ@2 pzD, Φ@2 sD, Φ@2 pxD<; sp3hybridsAlt = Map@MOtoStandardForm@ð, ΦD &, hybridsAltD 8Φ@2 pxD + Φ@2 pyD + Φ@2 pzD + Φ@2 sD, Φ@2 pxD + Φ@2 pyD - Φ@2 pzD - Φ@2 sD, Φ@2 pxD - Φ@2 pyD + Φ@2 pzD - Φ@2 sD, Φ@2 pxD - Φ@2 pyD - Φ@2 pzD + Φ@2 sD<
Are they the same? sp3hybrids == sp3hybridsAlt True
Symmetry takes care of everything. The order in which you list the basis functions of a space can't really matter for functions that use them symmetrically.
41.5 Electron density in sp3 orbitals Finally, we put the shell 2 hydrogen orbitals into Eq. 41.4 , producing the four famous sp3 hybrids already shown in the introduction. Click to them if you want to see them again. Here are the analytical forms :
532
Electron density
8fn2s, fn2px, fn2py, fn2pz< = -
ã :ã
1
-
1
-
1
ã
2
2
: 2-
x2 +y2 +z2
2
x2 +y2 +z2
x2 + y2 + z2
2-
x2 +y2 +z2
x2 + y2 + z2
-
x, ã
1
x2 +y2 +z2
2
, x, y, z>
, -
y, ã
1 2
x2 +y2 +z2
z>
Now make the sp3 hybrids :
8sp3A, sp3B, sp3C, sp3D< = bInv.8fn2s, fn2px, fn2py, fn2pz<; % Size@7D
:ã
-
1
x2 +y2 +z2
2
-
-ã
-
ã
1 2
x2 +y2 +z2
2
-
-ã
1
1
x2 +y2 +z2
2
x2 +y2 +z2
-
x+ã
1
-
x-ã
-
x+ã -
x-ã
x2 +y2 +z2
2
1
1
-
y+ã
x2 +y2 +z2
-
x2 +y2 +z2
-
y-ã
2
x2 +y2 +z2
2
-
y-ã
x2 +y2 +z2
2
y+ã
2
1
1
1
1
x2 +y2 +z2
2
1
x2 +y2 +z2
2
x2 +y2 +z2
2
-
z+ã
1
-
z+ã
-
z+ã -
z+ã
x2 +y2 +z2
2
1
1
x2 +y2 +z2
2
1
x2 +y2 +z2
2
x2 +y2 +z2
2
2-
x2 + y2 + z2
,
2-
x2 + y2 + z2
,
2-
x2 + y2 + z2
,
2-
x2 + y2 + z2
>
Three-D contour plots of these four functions are given in Fig. 41.2. Plot the amplitude squared of the sp3A hybrid orbital along a line x = y = z passing right down through its center :
3
-10
-5
5
10
3
Fig. 41.5 Electron density on the center line of an sp hybrid. It bonds to the right, where the mushroom cap is.
41.6 End Notes 533
Symmetry Theory
41.6 End Notes 41.6.1 Reference F. A. Cotton, 3rd ed. Section 8.5, pp. 222- 226
534
42. Vibration analysis Preliminaries
42.1. Problem and strategy Every molecule possess a small, finite number of normal modes of vibration, in which every atom moves harmonically around its rest position with the same frequency. The general vibrational motion, as excited by thermal collisions, is simply a sum of the normal mode motions, with random amplitudes and phases. But normal modes are easy to excite as pure motions. When an electromagnetic wave of the right frequency washes over a molecule, every atom feels a pushpull force, and if that force has the frequency of a normal mode, the whole molecule begins to move in that pure normal mode. This is the classical view of infrared absorption spectroscopy. In a molecule with n atoms, there are 3n atomic coordinates. Generally 3 are devoted to center of mass motion and three are devoted to rotation. That leaves 3n-6 internal configuration coordinates. The proper linear combination of these internal coordinates are the normal modes. If the forces between atoms are Hooke's Law forces (as they are for all small amplitude motions), it turns out that the problem is exactly soluble, and if the molecule has any symmetry at all, the normal modes have a beautiful geometric symmetry. A question now arises quite naturally: Of the 3n-6 modes of vibration, in a molecule of given group, how many belong to each symmetry species of the group? Are there species have no mode? How many modes are allowed for infrared absorption, and how many for Raman scattering, and how many are inactive for both? This chapter shows you how to answer these questions without a full-blown mode calculation. For example, when you read a reference to “the A2 u modes of benzene” you know something about them immediately. Pull out the BoxedCharacterTa ble for group D6 h and have a look. Since species A2 u transforms like z, you know immediately that (1) the A2 u modes are allowed in infrared spectra, and (2) they involve out-of-plane motion. This chapter shows you how to count how many modes will belong to each species, even before you do the mode calculation. The method is to make a representation of the group based on the 3-n atomic displacement coordinates of an n-atom molecule. This is a large representation, size 3n 3n, and it is highly reducible. Its analysis tells you everything you can know about the symmetry of the molecule's modes. It won't give you frequencies or exact mode geometries, but it will reveal everything about the mode W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, 535 symmetries. DOI 10.1007/b13137_42, © Springer Science+Business Media, LLC 2009
The method is to make a representation of the group based on the 3-n atomic displacement coordinates of an n-atom molecule. This is a large representation, Symmetry Theory
cies or exact mode geometries, but it will reveal everything about the mode symmetries. We will follow the recipe implicit in the master representation equation from Chapter 27 (MakeReps). The symmetrically transforming objects fk are the 3n atomic displacement coordinates used to describe the modes : The master representation equation T R @fk D =
HRL Ú fh Th,k
N@fD
for k
= {1,…,N[f]}
h=1
where T R is the transform for element R fh is basis object number h N@fD is the number of basis objects
(42.1)
HRL ) is the desired rep matrix for element R THRL h,k (or T
Here is the calculational strategy: The first job is to make an explicit list of the
displacements fk and calculate the left side, T R @fk D, the result of applying all the Cartesian transforms of the group to the displacements. The second job is to find the matrix THRL h,k on right side. This will be done as usual by MatrixOfCo efficients.
42.2. A step-by-step example 42.2.1 The methane example We will develop our formulas using methane as the example. The formulas lead to an algorithm (VibrationAnalysis[molecule,group], Section 42.4) that works for all molecules with one hit. But we develop it, as always by working out a concrete example. Here is the methane molecule, in standard position for its group, group Td .
536
Methane example
Fig. 42.1 Two views of the methane molecule in standard position. On the left, you can see the central carbon atom and the tetrahedrally arrayed C-H bonds. The right view emphasizes that the H atoms are at alternate corners of a cube.
Here is its character table: BoxedCharacterTable@"Td"D Td 1
8
3
6
6
¬ Class populations 9I x2 + y2 + z2 M=
E C3 C2 S4 Σd A1 1
1
1
A2 1
1
1
E
2 -1
2
Basis functions
-1 -1 9I -x4 y2 + x2 y4 + x4 z2 - y4 z2 - x2 z4 + y2 z4 M= 1
1
0
0
:
-x2 - y2 + 2 z2 3 x2 -
: -x2 y + y z2 , x y2 - x z2
T1 3
0
-1
1
-1
x2 z - y2 z T2 3
0
-1 -1
1
3 y2
x : y , z
>
Ix Iy > Iz
xy yz > xz
It will turn out that methane has no vibrations of species A2 or T1 . But you cannot see this ahead of time, without the calculation.
42.2.2 Make a displacement representation, step by step Every atom needs a displacement vector 8∆x , ∆y , ∆z <, which, when added to its rest position, tells where the atom is at every moment. But different molecules need different numbers of displacement vectors. A convenient way to construct the general set of displacement vectors is
537
Symmetry Theory
mol = "methane"; gp = "Td"; nDim = AtomCount@molD; ∆xs = Array@x, nDimD; ∆ys = Array@y, nDimD; ∆zs = Array@z, nDimD; dspColumns = 8∆xs, ∆ys, ∆zs<; % GridForm Size@9D x@1D y@1D z@1D
x@2D y@2D z@2D
x@3D y@3D z@3D
x@4D y@4D z@4D
x@5D y@5D z@5D
One of the Cartesian transforms of this group is Cz @ΠD, a two-fold rotation about z. In the “before” picture below we show H atoms 1 and 2, and the top of the cube that encloses the methane molecule. There is a small displacement 8∆x , ∆y < on atom 1 and a zero displacement on atom 2. In the “after” picture, the molecule has rotated by Cz @ΠD, carrying all its displacements with it.
before
after 2
1
2
1 Fig. 42.2 A small vibration displacement is subjected to Cz @ΠD
Before the rotation, the 2-atom displacement list is 0 -∆x 0 -∆y
. Two things have happened:
rotated by half a turn about z, becoming
∆x 0 ∆y 0
.
After, it is
First, the displacement vector -∆x -∆y
∆x ∆y
. Second, the rotation of the
whole molecule carried it from atom 1 to atom 2. Therefore, it moved from the first column to the second. This two-step transform has to be carried out on all the displacements in the molecule. The rotation matrix is Tmat = Cz @ΠD
88-1, 0, 0<, 80, -1, 0<, 80, 0, 1<<
Apply it to the displacement columns:
538
Methane example
dspTrf10 = Tmat.dspColumns; % GridForm Size@9D -x@1D -y@1D z@1D
-x@2D -y@2D z@2D
-x@3D -y@3D z@3D
-x@4D -y@4D z@4D
-x@5D -y@5D z@5D
Sure enough, every displacement vector was rotated by half a turn about z. Now we need something that will permute the columns appropriately. In fact, we already have it. When we were working with atomic orbital representations, we needed the permutation matrices that describe how identical atoms shift around in the molecule under each transform. Here they are again : permuMatsMol = MakeRepAtomic@mol, gpDP1T; This is too big to print completely. Lift out the 10th matrix (representing permutation {2,1,4,3,5}) : permuMatsMolP10T MatrixForm 0 1 0 0 0
1 0 0 0 0
0 0 0 1 0
0 0 1 0 0
0 0 0 0 1
It is a 5 ´5 matrix. We want to permute the columns of the 10th transformed displacement matrix, which is a 3 ´ 5 matrix. The only way these matrices can multiply is in the order (3 ´ 5).(5 ´ 5). But first, check out directly that this gives us what we want. We Dot the permutation matrix with an alphabetical (5 ´ 5) from both sides : a f : k p u
b g : l q v
b g l q v
c h m r w
a f k p u
d i n s x
e j o t y
0 1 . 0 0 0
d i n s x
c h m r w
e j o , t y
1 0 0 0 0
0 0 0 1 0
f a p k u
0 0 1 0 0
g b q l v
0 0 0 0 1
0 1 0 0 0
,
h c r m w
i d s n x
1 0 0 0 0
0 0 0 1 0
0 0 1 0 0
0 0 0 0 1
a f . k p u
b g l q v
c h m r w
d i n s x
e j o t y
> MatrixList
j e t > o y
The first product, mat.perm, permutes the columns, as we desire. The other way, perm.mat, permutes the rows. So the calculation is dspTrf10.permuMatsMolP10T; % MatrixForm
539
Symmetry Theory
-x@2D -x@1D -x@4D -x@3D -x@5D -y@2D -y@1D -y@4D -y@3D -y@5D z@2D z@1D z@4D z@3D z@5D
Perfect. The H atoms 1 and 2 have switched places, as have the other two, 3 and 4, while atom 5, the C atom, stayed put. So let's expand our horizons and do it all for all 24 transforms at once: nGp = GroupOrder@gpD; dspTrfPrm = Table@Inverse@CartRep@gpDPiTD. dspColumns.permuMatsMolPiT, 8i, 1, nGp
-y@2D -y@3D -y@1D -y@4D -y@5D z@2D z@3D z@1D z@4D z@5D , 20, -x@2D -x@3D -x@1D -x@4D -x@5D
-y@2D -y@1D -y@3D -y@4D -y@5D -x@2D -x@1D -x@3D -x@4D -x@5D , z@2D z@1D z@3D z@4D z@5D
824, 3, 5<
x@4D x@2D x@3D x@1D x@5D -z@4D -z@2D -z@3D -z@1D -z@5D > -y@4D -y@2D -y@3D -y@1D -y@5D
Each one of these 3 ´5 matrices needs to be made into a 15-element vector, reading down the first column, then down the second column, etc. dspTrfPrm2415 = Map@Flatten, Map@Transpose, dspTrfPrmDD; % Dimensions 824, 15<
We need the untransformed list explicitly, to use as a list of the original displacementVariables, or dspVars, for short. It is the first one above: dspVars = dspTrfPrm2415P1T
8x@1D, y@1D, z@1D, x@2D, y@2D, z@2D, x@3D, y@3D, z@3D, x@4D, y@4D, z@4D, x@5D, y@5D, z@5D<
This also checks that we put them in the desired order when we Transposed and Flattened. Now we are ready to extract the representation matrices. We will get one from each row of the 12 ´ 15 result above. We do not forget that MatrixOfCoefficients gives us the transpose of what we really want, so we wrap its output in a Transpose operator : repMatsMethaneTd = Map@Transpose, Map@MatrixOfCoefficients@ð, dspVarsD &, dspTrfPrm2415DD; %P810
540
Methane example
:
0 0 0 -1 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 -1 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 1 0 0 0 0 0 0 0 0 0
-1 0 0 0 0 0 0 0 0 0 0 0 0 0 0
0 -1 0 0 0 0 0 0 0 0 0 0 0 0 0
0 0 1 0 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 -1 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 -1 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 1 0 0 0
0 0 0 0 0 0 -1 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 -1 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 1 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 0 -1 0 0
0 0 0 0 0 0 0 0 0 0 0 0 0 -1 0
0 0 0 0 0 0 0 0 0 0 0 0 0 0 1
>
This is matrix 10, of size 15 ´ 15, from the list of 24 matrices. Interactive readers can see the whole list if they want to. Is the list a rep of group Td ? MorphTest@repMatsMethaneTd, gpD Faithful, or Isomorphic
Indeed it is. So the old recipe worked again.
42.3. Automate the displacement rep 42.3.1 Displacement representation automated We pull together the steps used above in 42.2.2, to make the displacement rep for methane. We replace methane by mol, and Td by gp , and generalize any variable names specific to the methane example. MakeRepDisplacement@mol_, gp_D := Module@ 8nGp, nDim, ∆xs, x, ∆ys, y, ∆zs, z, dspCols, permuMats, dspTrfPrm, dspTrfPrmMat, dspVars<, nGp = GroupOrder@gpD; nDim = AtomCount@molD; ∆xs = Array@x, nDimD; ∆ys = Array@y, nDimD; ∆zs = Array@z, nDimD; dspCols = 8∆xs, ∆ys, ∆zs<; permuMats = MakeRepAtomic@mol, gpDP1T; dspTrfPrm = Table@Inverse@CartRep@gpDPiTD. dspCols.permuMatsPiT, 8i, 1, nGp
Symmetry Theory
dspVars = dspTrfPrmMatP1T; Map@Transpose, Map@MatrixOfCoefficients@ð, dspVarsD &, dspTrfPrmMatDD D We test it in the next section.
42.3.2 One-click tests of MakeRepDisplacement
methane, group Td It had better work on the methane example: repMethaneTd = MakeRepDisplacement@"methane", "Td"D; Dimensions@repMethaneTdD 824, 15, 15<
MorphTest@repMethaneTd, "Td"D Faithful, or Isomorphic
It does. Here are a few molecules it has not seen before: ammonia, group C3 v repAmmoniaC3v = MakeRepDisplacement@"ammonia", "C3v"D; Dimensions@repAmmoniaC3vD 86, 12, 12<
MorphTest@repAmmoniaC3v, "C3v"D Faithful, or Isomorphic
ethylene, group D2 h repEthyleneD2h = MakeRepDisplacement@"ethylene", "D2h"D; Dimensions@repEthyleneD2hD 88, 18, 18<
MorphTest@repEthyleneD2h, "D2h"D 542
Automate displacement rep
Faithful, or Isomorphic
an octahedral complex OX6 , group O repOctaComplexO = MakeRepDisplacement@"octaComplex", "O"D; Dimensions@repEthyleneD2hD 88, 18, 18<
Dimensions@repOctaComplexOD 824, 21, 21<
MorphTest@repOctaComplexO, "O"D Faithful, or Isomorphic
uranium nonafluoride, group D3 h repUF9D3h = MakeRepDisplacement@"UF9", "D3h"D; Dimensions@repUF9D3hD 812, 30, 30<
MorphTest@repUF9D3h, "D3h"D Faithful, or Isomorphic
42.4. Analyze the vibrations 42.4.1 Make the character vector for the entire rep We continue with the methane example worked out in 42.2.2 . The final result was repMatsMethaneTd:. Make sure that Mathematica knows it : repMethaneTd = MakeRepDisplacement@mol, "Td"D; Dimensions@repMethaneTdD 824, 15, 15<
If the return above is anything other than {24,15,15}, go back and run 42.2.2 top to bottom with one click. First find the character of each matrix in the representation: 543
Symmetry Theory
extendedChs = Map@Spur, repMatsMethaneTdD 815, 0, 0, 0, 0, 0, 0, 0, 0, -1, -1, -1, -1, -1, -1, -1, -1, -1, 3, 3, 3, 3, 3, 3<
shortChs = OnePerClass@extendedChs, "Td"D 815, 0, -1, -1, 3<
analysisRaw = Analyze@shortChs, "Td"D
88A1, 1<, 8A2, 0<, 8E, 1<, 8T1, 1<, 8T2, 3<<
So the displacement representation of methane, if block diagonalized, would contain the irreducible representations A1 , E, and T1 , and three occurrences of T2 . You are guaranteed that no A2 will be present. More complicated Td molecules could have A2 modes, but methane does not have enough atoms to move with that symmetry. This is the kind of thing that symmetry analysis can tell you. How many modes is that? A1 is nondegenerate, E is doubly degenerate, while T1 and T2 are triply degenerate. So the number of raw modes is (1 ´1) + (2 ´1) + (3 ´1) + (3 ´3) = 15 modes. Good, that was the total number of displacement coordinates that we started with, so nothing has been lost. But not all these modes are vibrations. Three of them are translations and three are rotations, and we must remove them.
42.4.2 Remove translation modes and rotation modes Put the raw characters into a List without their species names : 8nmsRaw, chsRaw< = Transpose@analysisRawD 88A1, A2, E, T1, T2<, 81, 0, 1, 1, 3<<
First, make the subtractions due to x, y, and z translations. Fortunately, we have an operator that looks for them and brings them forth: translAnalysis = TranslationSpecies@gpD
88A1, 0<, 8A2, 0<, 8E, 0<, 8T1, 0<, 8T2, 8x, y, z<<<
8nmsT, translBases< = translAnalysis Transpose 88A1, A2, E, T1, T2<, 80, 0, 0, 0, 8x, y, z<<<
translLens = Map@Length, translBasesD 80, 0, 0, 0, 3<
544
Analyze displacement rep
translRemovals = translLens SpeciesDims@gpD 80, 0, 0, 0, 1<
Now make the subtractions due to Ix, Iy, and Iz rotations. We have an operator that fetches them: rotAnalysis = RotationSpecies@gpD
88A1, 0<, 8A2, 0<, 8E, 0<, 8T1, 8Ix, Iy, Iz<<, 8T2, 0<<
8nmsR, rotBases< = rotAnalysis Transpose 88A1, A2, E, T1, T2<, 80, 0, 0, 8Ix, Iy, Iz<, 0<<
rotLens = Map@Length, rotBasesD 80, 0, 0, 3, 0<
rotRemovals = rotLens SpeciesDims@gpD 80, 0, 0, 1, 0<
8SpeciesNames@gpD, chsRaw< = Transpose@analysisRawD 88A1, A2, E, T1, T2<, 81, 0, 1, 1, 3<<
And finally, here is the big subtraction: vibAnalysis = Transpose@ 8nmsRaw, chsRaw - rotRemovals - translRemovals
These are the vibrational modes of the molecule. The next step is to get it to run all in one cell; then, in the next section we make the cell into a module.
42.4.3 Automate it The entire vibrational analysis can be automated: VibrationAnalysis@mol_, gp_D := Module@ 8repMol, extendedChs, shortChs, analysisRaw, nmsRaw, chsRaw, transAnalysis, nmsT, translBases, translLens, translRemovals, rotAnalysis, nmsR, rotBases, rotLens, rotRemovals, spMS<, repMol = MakeRepDisplacement@mol, gpD; extendedChs = Map@Spur, repMolD; ; 545
Symmetry Theory
shortChs = OnePerClass@extendedChs, gpD; analysisRaw = Analyze@shortChs, gpD; 8nmsRaw, chsRaw< = Transpose@analysisRawD; translAnalysis = TranslationSpecies@gpD; 8nmsT, translBases< = translAnalysis Transpose; translLens = Map@Length, translBasesD; translRemovals = translLens SpeciesDims@gpD; rotAnalysis = RotationSpecies@gpD; 8nmsR, rotBases< = rotAnalysis Transpose; rotLens = Map@Length, rotBasesD; rotRemovals = rotLens SpeciesDims@gpD; 8SpeciesNames@gpD, chsRaw< = Transpose@analysisRawD; vibAnalysis = Transpose@8nmsRaw, chsRaw - rotRemovals - translRemovals
42.5. One-click examples We have tested the VibrationAnalysis algorithm on a number of molecules, and have not seen any failures so far. Here is a miscellaneous collection of some of the molecules we have tried it on: 1. Ethylene: 3Ag + Au + 2B1g + B1u + B2g + 2B2u + 2B3u (pictures in Herzberg, IR & Raman, p. 107) VibrationAnalysis@"ethylene", "D2h"D 88Ag, 3<, 8B1g, 2<, 8B2g, 1<, 8B3g, 0<, 8Au, 1<, 8B1u, 1<, 8B2u, 2<, 8B3u, 2<<
Perfect agreement for ethylene. 2. Carbonate: A1¢ +A2¢¢ +2 E¢ (pictures in Herzberg, IR & Raman, p. 179) VibrationAnalysis@"carbonate anion", "D3h"D
88A1¢ , 1<, 8A2¢ , 0<, 8E¢ , 2<, 8A1¢¢ , 0<, 8A2¢¢ , 1<, 8E¢¢ , 0<<
Exactly as listed by Herzberg.
546
One-click examples
3. Ammonia: 2 A1 + 2 E (pictures in Herzberg, IR & Raman, p. 110) VibrationAnalysis@"ammonia", "C3v"D 88A1, 2<, 8A2, 0<, 8E, 2<<
Again. 4. Equilateral ozone: A1¢ + E¢ (pictures in Herzberg, IR & Raman, p. 84, leftmost column) VibrationAnalysis@"equilateral ozone", "D3h"D 88A1¢ , 1<, 8A2¢ , 0<, 8E¢ , 1<, 8A1¢¢ , 0<, 8A2¢¢ , 0<, 8E¢¢ , 0<<
And again.
547
43. Multiple symmetries Preliminaries
43.1 Inspiration In quantum mechanics there are many occasions where quantum states are written as products of two or more functions, each with its own set of variables. For instance, spin-dependent wave functions Y@xi , yi , zi , si D are written as Ψ@xi , yi , zi D Φ@si D, or linear combinations thereof. In the BornOppenheimer approximation the electronic and vibrational wave functions are multiplied together to make the “vibronic” wave function : Y@electronic,
nuclearD
= Ψ@electronicD Φ@nuclearD
In all such cases the energy is a sum of two parts. In this chapter we address the question of how to make symmetry group representations using basis functions that are the product of two parts.
43.2 Reps made from products of basis functions Click back to the basic representation matrix formula, Eq. 25.1, and reread it and review the meanings of its symbols. We copy it into this chapter with a
small modification: we add an f to the superscript on matrix THRL h,k to indicate that the matrix was constructed on the basis of vectors named f. T R @fi D = â fh Th,i nf
h=1
HR,fL
HR,gL
Then another matrix TJ,K , representing element R on the basis of some other HR,gL
functions g would be calculated by solving for TJ,K in the equation T R @gK D = â gJ TJ,K ng
HR,gL
J=1
What would happen if we tried to make a representation on the basis of the i
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_43, © Springer Science+Business Media, LLC 2009
gK D, 549 the
Symmetry Theory
What would happen if we tried to make a representation on the basis of the
products fi gK ? The transform of the products will be written as T R @fi gK D, where we assume that T R can work on both the coordinates of the f's and the coordinates of the g's. By linearity of the transform T R @fi gK D = T R @fi D T R @gK D =
â fh Th,i
â gJ TJ,K
h=1
J=1
HR,fL
nf
HR,gL
NG
Rearranging the sum T R @fi gK D = â â Hfh gJ L JTh,i
HR,fL
nf NG
TJ,K N HR,gL
h=1 J=1
Let fu gV = HfgLu,V and rewrite as T R AHfgLi,K E = â â HfgLh,J JTh,i
HR,fL
nf NG
TJ,K N HR,gL
h=1 J=1
As its four indices run over all possible values, JTh,i
HR,fL
TJ,K Nruns over all HR,gL
HR,fL
possible products of pairs of elements of the two 2-index matrices Th,i and HR,gL
TJ,K . But to set things up so that they will fall into the form of a matrix multiplication, we must let Direct product of two representations HR,fgL
HR,fL
THh,JL,Hi,KL = Th,i
HR,gL
TJ,K
HR,fL
Note the re-pairing of indices on the left. Matrices Th,i square, but of different sizes. So
HR,fgL THh,iL,HJ,KL
HR,gL
and TJ,K
are each
would generally be rectangular,
of size nf2 ´ NG2 . But {h,J} runs over nf*NG values, as does {i,K}, so HR,fgL
the new re-paired matrix THh,JL,Hi,KL is square. In this notation T R AHfgLi,K E = â â HfgLh,J THh,JL,Hi,KL nf NG
h=1 J=1
Renaming {i,K} as Β and {h,J} as Α,
550
HR,fgL
Product representations
T R @HfgLΒ D =
â HfgLΑ TΑ,Β
nf*NG
HR,fgL
Α=1
We have recovered the defining equation for a representation matrix. It says HR,fgL
that matrix TΑ,Β
represents transform R in fg basis. Indices Α and Β run
from 1 to nf*NG. In the EndNotes we automate this process with DirectProduct[A,B].
43.3 Lemma: Character of a direct product The character of a direct product is a true one-liner : HR,fgL
ΧHR,fgL = TΑ,Α
HR,fgL
HR,fL
= THh,JL,Hh,JL = Th,h
HR,gL
TJ,J
= ΧHR,fL ΧHR,gL
There it is. The character of the direct product of A and B is the character of A times the character of B. We enshrine it in a box: ΧHR,f*gL = ΧHR,fL * ΧHR,gL The character of a product function is the product of the characters of its factors. Remember this; it's profound and very useful.
43.4 Vibronic examples 43.4.1 A one-dimensional example
551
Symmetry Theory
Fig. 43.1 StereoView of formaldehyde. Note the z,x reflecting plane.
The group is C2 v . The character table is $DefaultGroup = "C2v"; BoxedCharacterTable@D 1
1
¬ Class populations
C2v
1
A1 A2
E C2 Σvzx Σvyz Basis functions 1 1 1 1 8H z L, H x2 L, H y2 L, H z2 L< 1 1 -1 -1 8H x y L, H Iz L<
1
B1
1 -1
1
-1
B2
1 -1
-1
1
8H x L, H x z L, H Iy L< 8H y L, H y z L, H Ix L<
C2v 1
1
1
1
E C2 Σvzx Σvyz A1
1
1
1
1
A2
1
1
-1
-1
B1
1 -1
1
-1
B2
1 -1
-1
1
¬ Class populations 9H z L, I x2 M, I y2 M, I z2 M= Basis functions
8H x y L, H Iz L<
8H x L, H x z L, H Iy L< 8H y L, H y z L, H Ix L<
Suppose your molecule is in a B1 electronic state and a B2 vibrational state. Then its vibronic wave function is Y? @electronic, nuclearD = ΨB1 @electronic coordsD ΦB2 @nuclear coordsD. What is the symmetry species of Y? ? We answer by constructing a representation using ΨB1 ΦB2 as the basis function. Function ΨB1 is species B1 because it transforms like x; similarly, ΦB2 is species B2 because it transforms like y. So the product ΨB1 ΦB2 transforms like x*y. But looking at the character table, the function x*y is already there; it is the basis for species A2 . So that is the answer; the vibronic wave function is YA2 @electronic, nuclearD. Do it again, just a little more abstractly (this moves us toward examples that are not so easy). The Lemma was written for just one transform, but of course we can do it for the first transform of each class and get a whole character vector. This time we do it without thinking about the basis functions, but only at the character vectors. Taking the Times product of these two character vectors, we get 552
Do it again, just a little more abstractly (this moves us toward examples that are not so easy). The Lemma was written for just one transform, but of course we Vibronic examples
character vectors. Taking the Times product of these two character vectors, we get ChVec@"B1"D * ChVec@"B2"D 81, 1, -1, -1<
Remember, our theorem said “The character of the product is the product of the characters”, and here we see this borne out : ChVec@"A2"D
81, 1, -1, -1<
43.4.2 A two-dimensional example Say you are working with a molecule of group C4 v . The character table is $DefaultGroup = "C4v"; BoxedCharacterTable@D 1
2
1
A1
E C2 C4 Σv Σd Basis functions 1 1 1 1 1 8H z L, H x2 + y2 L, H z2 L<
A2 B1
1 1
1 1 -1 -1 1 -1 1 -1
B2
1
1 -1 -1
E
2 -2
0
2
¬ Class populations
C4v
2
8H Iz L< 8H x2 - y2 L< 8H x y L< x xz Ix :K O, K O, K O> y yz Iy
1
0
0
C4v 1
1
2
2
2
¬ Class populations
9H z L, I x2 + y2 M, I z2 M= -1 -1 8H Iz L<
E C2 C4 Σv Σd A1
1
1
1
A2
1
1
1
B1
1
1
-1
B2
1
1
-1 -1
E
2 -2
0
1
1
1
-1
0
1 0
Basis functions
:K
9I x2 - y2 M= 8H x y L<
x xz O, K O, y yz
Ix > Iy
Suppose your molecule is in an E electronic state and an A1 vibrational state. This means the electronic excitation was provoked by a polarization vector in the x,y plane, while the vibration was provoked by a z-polarized IR photon. Its vibronic wave function is Y? @electronic, nuclearD = ΨE @electronic D ΦA1 @nuclearD. What is the symmetry of Y? ? If the electronic state is E, there must be two linearly independent wave functions at the same energy, and when they are used as the bases of a representation its character vector is {2,-2,0,0,0}. The vibration is not degenerate, and it supports a representation with character vector {1,1,1,1,1}. The dimension of the product representation is 1*2 = 2. The product of the characters is 553
vibronic wave function is Y? @electronic, nuclearD = ΨE @electronic D ΦA1 @nuclearD. What is the symmetry of Y? ? If the electronic state is E, there must be two linearly independent wave functions at the same energy, and when they are used Symmetry Theory as the bases of a its character vector is {2,-2,0,0,0}. The vector {1,1,1,1,1}. The dimension of the product representation is 1*2 = 2. The product of the characters is ChVec@"E"D * ChVec@"A1"D == ChVec@"E"D True
By our Lemma this is the character of the product; namely, just species E again. So the vibronic wave function Y@electronic, nuclearD is of overall species E.
43.4.3 A four-dimensional example Now we will begin to see the power of the little lemma. Stick with the C4 v molecule but consider an excited state that is E in the electronic excitation and also E in the vibrational excitation. Now the dimension of the product representation must be 2*2 = 4. This obviously cannot be a pure simple symmetry because the irreducible reps are all of dimension 1 or 2. Nevertheless, the Lemma still works : ChVec@"E"D * ChVec@"E"D 84, 4, 0, 0, 0<
It is really beautiful to be able to compute the product state character vector without going to the trouble of computing its representation. To extract the information in this result, we determine what irreducible representations occur on the block diagonals when the (unknown) rep is reduced. Fortunately, this is also possible without knowing the actual 4-D rep : Analyze@84, 4, 0, 0, 0
88A1, 1<, 8A2, 1<, 8B1, 1<, 8B2, 1<, 8E, 0<<
So in group C4 v the E*E excitation is a linear combination of the four simple symmetries, one of each species except E. So the vibronic wave function is not necessarily of any pure symmetry type.
43.4.4 Example using simple functions We can easily show a concrete example of this calculation. We will not use actual molecular wave functions, but simple functions that have the same symmetry. You can see from the character table that two simple functions that support the E rep are {x,y}, and we will use these as stand-ins for the electronic degenerate electronic states. We need a different pair that transforms according to E to use as stand-ins for the vibrational state. It is easy to concoct such a pair : 554
Vibronic examples
ProjectETA9x3 , y3 =E
98A1, 80, 0<<, 8A2, 80, 0<<,
8B1, 80, 0<<, 8B2, 80, 0<<, 9E, 9x3 , y3 ===
Now we make an “electronic state” as a linear combination of the two E functions above, and we make the “vibrational state” as a linear combination of x and y (using GothicCapitals as arbitrary coefficients) : Ψvibronic = IA x3 + B y3 M HC x + D y L Expand x4 A C + x y3 B C + x3 y A D + y4 B D
Our character calculation above said that this “vibronic state” could have components of any species but E. So we project it and see if that is true : vibrProj = ProjectET@Ψvibronic D; Column@%D :A1,
1 2
x4 A C +
1 2
y4 A C +
:A2, - 2 x3 y B C + 1
:B1, :B2,
1 2
x4 A C -
1 2
x3 y B C +
8E, 0<
1 2
1 2
x4 B D +
x y3 B C +
y4 A C 1 2
1 2
1 2
1 2
1 2
y4 B D>
x3 y A D -
x4 B D +
x y3 B C +
1 2
1 2
1 2
x y3 A D>
y4 B D>
x3 y A D +
1 2
x y3 A D>
Egad. It is true. Maybe all this malarkey means something, after all. Do they add up to the original? Pull out all the projections, and add them up: HHvibrProj TransposeLP2TL . List ® Plus Simplify Ix3 A + y3 BM Hx C + y DL
This is exactly what we started with. Look at a numerical example to understand this a little better. If we let {A®0,B®2,C®1,D®1} then the projection is ProjectETA 2 y3 Hx + yLE
99A1, x4 + y4 =, 9A2, -x3 y + x y3 =,
9B1, -x4 + y4 =, 9B2, x3 y + x y3 =, 8E, 0<=
and here are the plots:
555
Symmetry Theory
A1
A2
B1
B2
Fig. 43.2 In C4 v , the product of two functions of species E is a function that contains species A1 , A2 , B1 , and B2 .
43.5 End Notes 43.5.1 If H is a sum and Y is a product, the energy is a sum Assume that the Hamiltonian is a sum of two parts H = H1 + H2 where H1 and H2 work on different coordinates. Assume also that the wave function is a product Y = Ψ1 Ψ2 , where H1 @Ψ1 D = E1 Ψ1 and H2 @Ψ2 D = E2 Ψ2 . Then Schrödinger's equation H@YD = Etot Y becomes H@YD = HH1 + H2 L@Ψ1 Ψ2 D = H1 @Ψ1 Ψ2 D + H2 @Ψ1 Ψ2 D
But H1 and H2 work on different coordinates, so to H1 the function Ψ2 is just a constant, and vice-versa, so it may be factored out of the operand. So the calculation continues with Ψ2 H1 @Ψ1 D + Ψ1 H2 @ Ψ2 D = Ψ2 E1 Ψ1 + Ψ1 E2 Ψ2 and this becomes HE1 + E2 L Ψ1 Ψ2 = Etot Y
Under these assumptions, Etot is the sum of two parts E1 + E2 .
43.5.2 Example : (general 3 ´3) Ä (general 2 ´2) IMPORTANT NOTE In the standard preliminaries we Symbolize anything with a subscript. However, in this chapter we block this symbolization, because now we are going to perform transformations on matrix subscripts. Test whether subscript symbolization is active: Head@x0 D
Subscript
The return above should be Subscript. If it is Symbol, you must quit Mathe556tica and start this chapter again in a fresh session. Otherwise, everything below will be garbage.
End Notes
The return above should be Subscript. If it is Symbol, you must quit Mathematica and start this chapter again in a fresh session. Otherwise, everything below will be garbage. Construct the direct product matrix You will rarely need to construct a full direct product matrix, but it is very HR,fL
clarifying to carry out one simple example. Let Th,i MatA = HR,gL
and let TJ,K
MatB =
be
a1,1 a1,2 a1,3 a2,1 a2,2 a2,3 ; a3,1 a3,2 a3,3 be b1,1 b1,2 ; b2,1 b2,2
We construct JTh,i
HR,fL
TJ,K Nusing the Outer operator : HR,gL
outerAB = Outer@Times, MatA, MatBD 8888a1,1 88a1,2 88a1,3 888a2,1 88a2,2 88a2,3 888a3,1 88a3,2 88a3,3
b1,1 , b1,1 , b1,1 , b1,1 , b1,1 , b1,1 , b1,1 , b1,1 , b1,1 ,
a1,1 a1,2 a1,3 a2,1 a2,2 a2,3 a3,1 a3,2 a3,3
b1,2 <, b1,2 <, b1,2 <, b1,2 <, b1,2 <, b1,2 <, b1,2 <, b1,2 <, b1,2 <,
8a1,1 8a1,2 8a1,3 8a2,1 8a2,2 8a2,3 8a3,1 8a3,2 8a3,3
b2,1 , b2,1 , b2,1 , b2,1 , b2,1 , b2,1 , b2,1 , b2,1 , b2,1 ,
a1,1 a1,2 a1,3 a2,1 a2,2 a2,3 a3,1 a3,2 a3,3
b2,2 <<, b2,2 <<, b2,2 <<<, b2,2 <<, b2,2 <<, b2,2 <<<, b2,2 <<, b2,2 <<, b2,2 <<<<
What happened here? The Outer product came out as a 3 ´3 matrix of 3 ´3 matrices that might be written as a1,1 MatB a1,2 MatB a1,3 MatB a2,1 MatB a2,2 MatB a2,3 MatB a3,1 MatB a3,2 MatB a3,3 MatB
== outerAB
True
On the left above it is clear that all possible products of the elements of the two matrices were taken. This is the essence of Outer-ness. However, it is not very useful as a raw outer product. First, get rid of the complicated bracketing: outerAB2 = Flatten@outerABD
557
Symmetry Theory 8a1,1 a1,2 a2,1 a2,2 a3,1 a3,2
b1,1 , b2,1 , b1,1 , b2,1 , b1,1 , b2,1 ,
a1,1 a1,2 a2,1 a2,2 a3,1 a3,2
b1,2 , b2,2 , b1,2 , b2,2 , b1,2 , b2,2 ,
a1,1 a1,3 a2,1 a2,3 a3,1 a3,3
b2,1 , b1,1 , b2,1 , b1,1 , b2,1 , b1,1 ,
a1,1 a1,3 a2,1 a2,3 a3,1 a3,3
b2,2 , b1,2 , b2,2 , b1,2 , b2,2 , b1,2 ,
HR,fL
Now re-pair the indices, implementing Th,i
a1,2 a1,3 a2,2 a2,3 a3,2 a3,3
HR,gL
TJ,K
b1,1 , b2,1 , b1,1 , b2,1 , b1,1 , b2,1 ,
a1,2 a1,3 a2,2 a2,3 a3,2 a3,3
HR,fgL
b1,2 , b2,2 , b1,2 , b2,2 , b1,2 , b2,2 <
® THh,JL,Hi,KL
outerAB3 = outerAB2 . 8ah_,i_ bJ_,K_ ® ab88h,J<,8i,K<< <
8ab881,1<,81,1<< , ab881,1<,81,2<< , ab881,2<,81,1<< , ab881,2<,81,2<< , ab881,1<,82,1<< , ab881,1<,82,2<< , ab881,2<,82,1<< , ab881,2<,82,2<< , ab881,1<,83,1<< , ab881,1<,83,2<< , ab881,2<,83,1<< , ab881,2<,83,2<< , ab882,1<,81,1<< , ab882,1<,81,2<< , ab882,2<,81,1<< , ab882,2<,81,2<< , ab882,1<,82,1<< , ab882,1<,82,2<< , ab882,2<,82,1<< , ab882,2<,82,2<< , ab882,1<,83,1<< , ab882,1<,83,2<< , ab882,2<,83,1<< , ab882,2<,83,2<< , ab883,1<,81,1<< , ab883,1<,81,2<< , ab883,2<,81,1<< , ab883,2<,81,2<< , ab883,1<,82,1<< , ab883,1<,82,2<< , ab883,2<,82,1<< , ab883,2<,82,2<< ,
ab883,1<,83,1<< , ab883,1<,83,2<< , ab883,2<,83,1<< , ab883,2<,83,2<< <
They are re-paired, but they are not in Sorted order. This step is important but cannot easily be discussed in general notation, so we don't have a formula from the derivation to show you. Nevertheless, we sort them : sortedAB = outerAB3 Sort
8ab881,1<,81,1<< , ab881,1<,81,2<< , ab881,1<,82,1<< , ab881,1<,82,2<< , ab881,1<,83,1<< , ab881,1<,83,2<< , ab881,2<,81,1<< , ab881,2<,81,2<< , ab881,2<,82,1<< , ab881,2<,82,2<< , ab881,2<,83,1<< , ab881,2<,83,2<< , ab882,1<,81,1<< , ab882,1<,81,2<< , ab882,1<,82,1<< , ab882,1<,82,2<< , ab882,1<,83,1<< , ab882,1<,83,2<< , ab882,2<,81,1<< , ab882,2<,81,2<< , ab882,2<,82,1<< , ab882,2<,82,2<< , ab882,2<,83,1<< , ab882,2<,83,2<< , ab883,1<,81,1<< , ab883,1<,81,2<< , ab883,1<,82,1<< , ab883,1<,82,2<< , ab883,1<,83,1<< , ab883,1<,83,2<< , ab883,2<,81,1<< , ab883,2<,81,2<< ,
ab883,2<,82,1<< , ab883,2<,82,2<< , ab883,2<,83,1<< , ab883,2<,83,2<< <
The Sort operator does a nice job here, but generally we will need this same reordering in cases where there are no explicit indices for Sort to work on. To reorder a product matrix without subscripts, we would need the permutation that turns outerAB3 into sortedAB : perm36 = Map@Position@outerAB3, ðD &, sortedABD Flatten
558
End Notes 81, 2, 5, 6, 9, 10, 3, 4, 7, 8, 11, 12, 13, 14, 17, 18, 21, 22, 15, 16, 19, 20, 23, 24, 25, 26, 29, 30, 33, 34, 27, 28, 31, 32, 35, 36<
This permutation would be used as shown on the left side below : outerAB3Pperm36T == sortedAB True
Now we are ready to carry out the transform from double indices to single HR,fgL
HR,fgL
indices (THh,JL,Hi,KL ® TΑ,Β
). In the MatrixReview, it is shown that the
desired rule is {r_,c_} ® cMax (r-1)+c so we make a rule that uses it twice : Clear@h, i, J, KD; toTwoIndices = 8ab88h_,J_<,8i_,K_<< ® ab82 Hh-1L+J,2 Hi-1L+K< <; Convert from a four-index array (sortedAB) to a two-index array (sortedAB2): sortedAB2 = sortedAB . toTwoIndices
8ab81,1< , ab81,2< , ab81,3< , ab81,4< , ab81,5< , ab81,6< , ab82,1< , ab82,2< , ab82,3< , ab82,4< , ab82,5< , ab82,6< , ab83,1< , ab83,2< , ab83,3< , ab83,4< , ab83,5< , ab83,6< , ab84,1< , ab84,2< , ab84,3< , ab84,4< , ab84,5< , ab84,6< , ab85,1< , ab85,2< , ab85,3< , ab85,4< , ab85,5< , ab85,6< ,
ab86,1< , ab86,2< , ab86,3< , ab86,4< , ab86,5< , ab86,6< <
And finally sortedAB3 = Partition@sortedAB2, 6D; % GridForm ab81,1< ab82,1< ab83,1< ab84,1< ab85,1< ab86,1<
ab81,2< ab82,2< ab83,2< ab84,2< ab85,2< ab86,2<
ab81,3< ab82,3< ab83,3< ab84,3< ab85,3< ab86,3<
ab81,4< ab82,4< ab83,4< ab84,4< ab85,4< ab86,4<
ab81,5< ab82,5< ab83,5< ab84,5< ab85,5< ab86,5<
ab81,6< ab82,6< ab83,6< ab84,6< ab85,6< ab86,6<
The final direct product matrix is square, and 6 ´6. Reading it like a page, the a factors go a1,1 , ¼, a3,3 three times, while the b factors go b1,1 nine times, then b1,2 nine times, then b21 ; then b22 . Verification of the character lemma 559
Symmetry Theory
Verification of the character lemma dpSpur1 = Spur@sortedAB3D ab81,1< + ab82,2< + ab83,3< + ab84,4< + ab85,5< + ab86,6<
The theorem says this should be the product of the character of MatA times the character of MatB : dpSpur1 == Expand@Spur@MatAD Spur@MatBDD ab81,1< + ab82,2< + ab83,3< + ab84,4< + ab85,5< + ab86,6< a1,1 b1,1 + a2,2 b1,1 + a3,3 b1,1 + a1,1 b2,2 + a2,2 b2,2 + a3,3 b2,2
Let's see if we can transform it step by step to give this. In dpSpur1 we make both single indices into double indices. (Here is where it is essential to have symbolization of subscript expressions turned off.) dpSpur2 = dpSpur1 . ab8i1_,i2_< ®
ab8MakeDoubleIndex@i1,82,3
ab881,1<,81,1<< + ab881,2<,81,2<< + ab881,3<,81,3<< + ab882,1<,82,1<< + ab882,2<,82,2<< + ab882,3<,82,3<<
Resort them:
dpSpur3 = dpSpur2 . ab88i_,K_<,8j_,L_<< ® a8K,L< b8i,j< a81,1< b81,1< + a82,2< b81,1< + a83,3< b81,1< + a81,1< b82,2< + a82,2< b82,2< + a83,3< b82,2<
and factor:
dpSpur4 = dpSpur3 Factor
Ha81,1< + a82,2< + a83,3< L Hb81,1< + b82,2< L
The theorem is verified.
560
End Notes
If the return above is anything other than Ha81,1< + a82,2< + a83,3< L Hb81,1< + b82,2< L you need to click back and read the note at the top of Subsection 43.5.2 .
43.5.3 Automation
Module MakeDirectProductPerm The example showed us that we need a permutation to reorder the elements of the raw Outer product. It will, of course, depend on the dimensions of the example you are working with. The following operator carries out a fully indexed direct product calculation; then it uses the Sort operator to create the final ordering. Comparing the initial and final ordering, it returns the needed permutation. MakeDirectProductPerm@szA_, szB_D := Module@ 8MatA, i, j, MatB, outerAB, directAB4, to2Indcs, directAB2, sortedAB2<, MatA = Table@ai,j , 8i, 1, szA<, 8j, 1, szA
outerAB = Outer@Times, MatA, MatBD Flatten; directAB4 = outerAB . ai_,j_ bm_,n_ ® ab88i,m<,8j,n<< ; to2Indcs = 8ab88i_,j_<,8m_,n_<< ® ab8szB Hi-1L+j,szB Hm-1L+n< <;
directAB2 = directAB4 . to2Indcs; sortedAB2 = directAB2 Sort; Map@Position@directAB2, ðD &, sortedAB2D Flatten H*endModule*LD Test it : newPerm36 = MakeDirectProductPerm@3, 2D
81, 2, 5, 6, 9, 10, 3, 4, 7, 8, 11, 12, 13, 14, 17, 18, 21, 22, 15, 16, 19, 20, 23, 24, 25, 26, 29, 30, 33, 34, 27, 28, 31, 32, 35, 36<
The perm we made by direct sorting was called perm36. Is this result the same? newPerm36 == perm36 561
Symmetry Theory
True
Module DirectProduct Once the required permutation is known, construction of the direct product is straightforward : Clear@DirectProductD; DirectProduct@matA_, matB_D := Module@ 8dimA, dimB, permAB, outerAB, directAB<, dimA = Dimensions@matADP1T; dimB = Dimensions@matBDP1T; permAB = MakeDirectProductPerm@dimA, dimBD; outerAB = Outer@Times, matA, matBD Flatten; directAB = outerABPpermABT ; Partition@directAB, dimA * dimBD D DirectProduct differs from Outer because of that Permute operation (outerABPpermABT) that put the elements in sorted index order. Automated examples To a human this looks pretty much like the primary example above. But to a computer it is quite different; it has no explicit indices inside the matrices, so Sort cannot put the product elements in sorted index order. We must to rely on MakeDirectProductPerm to reorder the elements. MatC =
a b c d e f ; g h i
MatD = K
A B O; C D
outerCD = Outer@Times, MatC, MatDD Flatten
8a A, a B, a C, a D, A b, b B, b C, b D, A c, B c, c C, c D, A d, B d, C d, d D, A e, B e, C e, D e, A f, B f, C f, D f, A g, B g, C g, D g, A h, B h, C h, D h, A i, B i, C i, D i<
permCD = MakeDirectProductPerm@3, 2D
81, 2, 5, 6, 9, 10, 3, 4, 7, 8, 11, 12, 13, 14, 17, 18, 21, 22, 15, 16, 19, 20, 23, 24, 25, 26, 29, 30, 33, 34, 27, 28, 31, 32, 35, 36<
directCD = Partition@outerCDPpermCDT, 6D; % GridForm aA aC
562
aB aD
Ab bC
bB bD
Ac cC
Bc cD
End Notes
Ad Cd Ag Cg
Bd dD Bg Dg
Ae Ce Ah Ch
Be De Bh Dh
Af Cf Ai Ci
Bf Df Bi Di
The DirectProduct operator constructed above should give the same answer as all these maneuvers : directCD == DirectProduct@MatC, MatDD True
It does.
563
44. One-photon selection rules Preliminaries
44.1 The main idea In spectroscopy the quantum amplitude of a process is given by a matrix element of the form XΨo È P È Ψf \, where Ψoriginal is the wave function for
the starting state of the transition, Ψfinal is the final state, and P is the operator for a particular process, such as electric dipole moment, magnetic dipole moment, electric quadrupole moment, etc. In absorption spectroscopy, Ψo is nearly always the ground state, and Ψf is the excited state created by the absorption. In emission spectroscopy, vice-versa. It is frequently found that this matrix element vanishes, in which case the imagined process does not occur, and is called “forbidden”. What is not forbidden is “allowed”, and group theory makes it very easy to tell which is which for any given transition in any kind of spectroscopy (for any given spectroscopic operator P).
44.2 Polarization vectors and light amplitude We eschew the full development of the operators P. They are described in every quantum mechanics book, and we will just use the results. But we do want to make a little refinement that helps tremendously with the planning of experiments; we work with explicit, normalized polarization vectors. First, we assume that the light has a pure polarization of some kind (linear, circular, or elliptical). Truly “unpolarized” light is rarely found in reality, and is handled by a further development of the theory. (Most light is “partly polarized”, a statistical concept that we do not need here.) For one-photon electric dipole processes (absorption, fluorescence, phosphorescence) the theory says that the operator in the matrix element must be P = Ea Λ .{x,y,z} where real number Ea is the amplitude of the electric field of the light, Λ is the polarization vector of the light, and {x,y,z} are the Cartesian coordinates of the “particle” (electron or nucleus) that is interacting with the light. If there are many electrons or nuclei you simply use a sum over their coordinates, n
x
z
so
is lost if we
to one
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_44, © Springer Science+Business Media, LLC 2009
565 the
Λ is
P = Ea Λ .{x,y,z} where real number Ea is the amplitude of the electric field of the light, Λ is the polarization vector of the light, and {x,y,z} are the Cartesian coordinates of Symmetry Theory “ Úni=1 8xi , yi zi <, so nothing important is lost if we simplify to one particle. The polarization vector is always normalized by Λ.Λ* = 1, and it tells how the electric field oscillates. If Λ is real, E oscillates in a in a straight line; if Λ is complex it oscillates in an ellipse or a circle. Click to an End Note if you need to brush up on this. The amplitude of the spectroscopic process thus becomes
A = ZΨo Ë 8x, y, z<. Λ Ea Ë Ψf ^ = Ea Λ.XΨo È 8x, y, z< È Ψf \
The spectroscopic signal S (events per second) is proportional to A¤2 , so the signal is S µ A¤2 = ¢Ea Λ.XΨo È 8x, y, z< È Ψf \¦
2
We mention this here because the electric field A is often complex. This is perfectly alright. The absolute square of A is the only thing that relates to the signal, and it is always real.
Switching to a more systematic notation, we let 8x, y, z< = 8Ξ1 , Ξ2 , Ξ3 < and 8Λx , Λy , Λz < = 8Λ1 , Λ2 , Λ3 <, and S becomes S µ Ea2 ¡Λi XΨo È Ξi È Ψf \¥
2
where the sum over i is implied by its double occurrence. So the allowed or forbidden nature of the transition comes down to whether or not we get zero for the matrix elements XΨo È Ξi È Ψf \ for i = 1,2,3. This question is easy to decide using direct product theory. We bring together two previous results : 1. (Chapter 43) The character of a product of functions is the product of the characters of its factor functions. The function is the whole integrand of the matrix element : Ψo * Ξi Ψf We want the character of this product. We know the character of each of the factors: Ψo and Ψf are eigenfunctions of a molecular Hamiltonian that belongs to some symmetry group G, and they must have some pure symmetry (i.e., they must belong to some species of group G). The function Ξi also has a pure symmetry (it is just one of the Cartesian coordinates), and you can look up its species in the character table for group G. So we can easily take the product of the characters and reduce it to find the species present in the integrand. 2. (Chapter 39) If a function has no totally symmetric component, its integral vanishes. The product of the characters generally comes out as the character of a reducible representation. If so, use the Analyze operator to split it into its irreducible components. If the totally symmetric species is not present, the integral van566 ishes. Let's do an example immediately.
Polarization and amplitude
The product of the characters generally comes out as the character of a reducible representation. If so, use the Analyze operator to split it into its irreducible components. If the totally symmetric species is not present, the integral vanishes. Let's do an example immediately. We will work with the benzene orbitals, so click back and pull them to the side so you can see them while you read. Remember, these are not full benzene wave functions; they are just one-electron orbitals for six attractive centers. Also, remember that these model orbitals have no z dependence. So this example is not quite like doing the real molecule, but it serves. The group is D6 h : BoxedCharacterTable@"D6h", 6D D6h 1
2
E C6
2
1
1
3 C¢ 2 1
C¢¢ inv S3 2 1 1 1
C3 C2
A1g 1
1
1
A2g 1
1
3
1
2
2
1
S6 Σh 1
1
3
3
¬ Class populations
Σd
Σv
1
1
9I x2 + y2 M, I z2 M=
1
-1
-1 -1 9I -3 x5 y + 10 x3 y3 - 3 x y5 M, H Iz L=
1
1
-1
-1
1
1
1
1
B1g 1 -1
1
-1
1
-1
1
-1
1
-1
B2g 1 -1
1
-1 -1
1
1
-1
1
-1 -1
0
0
2
1
0
0
2
E1g 2
1
-1 -2
E2g 2 -1 -1
2
-1 -2
-1 -1
2
0
0
0
0
1
1
1
1
1
-1
-1 -1 -1 -1 -1
A2u 1
1
1
1
-1
-1
-1
-1 -1 -1
1
B1u 1 -1
1
-1
1
-1
-1
1
-1
1
-1
1
B2u 1 -1
1
-1 -1
1
-1
1
-1
1
1
-1
0
0
-2
-1
1
2
0
0
0
0
-2
1
1
-2
0
0
1
-1 -2
E2u 2 -1 -1
2
9I x3 z - 3 x y2 z M=
9I -3 x2 y z + y3 z M= xz Ix : , > yz Iy
1
A1u 1
E1u 2
Basis functions
1
:
x2
-
2 xy
y2 2
>
9I -3 x5 y z + 10 x3 y3 z - 3 x y5 z M= 8H z L< 9I 3 x2 y - y3 M=
9I -x3 + 3 x y2 M= x : > y :
x2 z 2 xyz
-
y2 z 2
>
The totally symmetric species is named A1 g in this group. What are the species of the Cartesian coordinates? The table says x and y transform together under species E1 u , while z transforms under species A2 u . Suppose we have an electron in the lowest orbital A1 g and we want to promote it to the E1 u level. Is there a photon that will do this? We need the character of a product function. So we take the character of HΨo * LHΞi LH Ψf L: $DefaultGroup = "D6h"; productChVec = ChVec@"A1g"D * ChVec@"E1u"D * ChVec@"E1u"D 84, 1, 1, 4, 0, 0, 4, 1, 1, 4, 0, 0<
From the 4 in the first position we see that this is the character vector of a 4 ´4 representation; definitely reducible. How does it block diagonalize? Analyze@productChVecD
567
Symmetry Theory 88A1g, 1<, 8A2g, 1<, 8B1g, 0<, 8B2g, 0<, 8E1g, 0<, 8E2g, 1<, 8A1u, 0<, 8A2u, 0<, 8B1u, 0<, 8B2u, 0<, 8E1u, 0<, 8E2u, 0<<
Yes! The total integrand has an A1 g component, so the transition A1 g ® E1 u is allowed for linear photons polarized in some direction that lies in the x,y plane. But if it is z polarized (species A2u) : HChVec@"A1g"D * ChVec@"A2u"D * ChVec@"E1u"DL Analyze
88A1g, 0<, 8A2g, 0<, 8B1g, 0<, 8B2g, 0<, 8E1g, 1<, 8E2g, 0<, 8A1u, 0<, 8A2u, 0<, 8B1u, 0<, 8B2u, 0<, 8E1u, 0<, 8E2u, 0<<
No! The A1 g component is zero, so the transition A1 g ® E1 u is forbidden for out-of-plane (or z) polarization.
44.3 Projection of the one-photon dipole operator Here is a nice way to look at this problem if you have automated projection operators. We return to the spectroscopic amplitude and pull out a part of it : Λ.XΨo È 8x, y, z< È Ψf \ We project the dipole moment operator under group D6 h , selecting only nonzero results : ProjectET@8x, y, z
It has split into two parts: {0,0,z} (species A2 u ) and {x,y,0} (species E1 u ). So suppose you are thinking about an A1 g ® E1 u transition. You will want to do the matrix element ME = XΨA1g È 8x, y, 0< È ΨE1u \ But of course ΨE1u is degenerate; it belongs to a family. You have to pick a particular family member to do the integral. Family members are given by ΨE1u @ΘD = Cos@ΘD ΨE1ux + Sin@ΘD ΨE1uy and the matrix element becomes ME = XΨA1g È 8x, y, 0< È Cos@ΘD ΨE1ux + Sin@ΘD ΨE1uy \ or 568 or
ME = Cos@ΘD XΨA1g È 8x, y, 0< È ΨE1ux \ + Sin@ΘD XΨA1g È 8x, y, 0< È ΨE1uy \
ΨE1u @ΘD = Cos@ΘD ΨE1ux + Sin@ΘD ΨE1uy and the matrix element becomes
One-photon operator
ME = XΨA1g È 8x, y, 0< È Cos@ΘD ΨE1ux + Sin@ΘD ΨE1uy \ ME = Cos@ΘD XΨA1g È 8x, y, 0< È ΨE1ux \ +
or
Sin@ΘD XΨA1g È 8x, y, 0< È ΨE1uy \
ME = Cos@ΘD 8XΨA1g È x È ΨE1ux \, XΨA1g È y È ΨE1ux \, 0< +
or
Sin@ΘD 8XΨA1g È x È ΨE1uy \, XΨA1g È y È ΨE1uy \, 0<
Function ΨA1 g x is of is of species E1 ux , like x itself, so we call it ΦE1ux , and similarly for ΦE1uy . Then the expression above becomes ME = Cos@ΘD 8XΦE1u,x È ΨE1u,x \, XΦE1u,y È ΨE1u,x \, 0< + Sin@ΘD 8XΦE1u,x È ΨE1u,y \, XΦE1ux,y È ΨE1u,y \, 0<
Now XΦE1u,y È ΨE1u,x \ and XΦE1u,x È ΨE1u,y \ have different species in them and by the Bedrock Theorem they must vanish, leaving ME = Cos@ΘD 8XΦE1u,x È ΨE1u,x \, 0, 0< + Sin@ΘD :0, [ΦE1ux,y Ì ΨE1u,y _, 0>
But by the Bedrock Lemma, XΦE1u,x È ΨE1u,x \ and XΦE1ux,y È ΨE1u,y \ must have the same value (call it Μ). So the matrix element becomes ME=Cos@ΘD 8Μ, 0, 0< + Sin@ΘD 80, Μ, 0< or The matrix element comes down to a wonderfully simple formula : XΨA1g È 8x, y, 0< È ΨE1u @ΘD\ = Μ 8Cos@ΘD, Sin@ΘD, 0< where Θ is the family parameter of the excited state. This must be dotted with the polarization vector Λ. Assuming that Λ is linear and x-polarized ({1,0,0}), we have
A == Ea Μ 81, 0, 0<.8Cos@ΘD, Sin@ΘD, 0<
A Ea Μ Cos@ΘD
and the differential signal due to family members within dΘ of Θ is â S µ Ea2 Μ2 Cos@ΘD2 â Θ Conveniently, Ea2 is proportional to light intensity (photons/second). Remember, the family formula was 569
Symmetry Theory
Conveniently, Ea2 is proportional to light intensity (photons/second). Remember, the family formula was ΨE1u @ΘD = Cos@ΘD ΨE1ux + Sin@ΘD ΨE1uy
Because the light is x-polarized, the signal is maximum for Θ = 0°, decreasing to 0 for Θ = 90°. The state produced at Θ = 0° is pure ΨE1ux , mixing with increasing amounts of ΨE1uy as Θ increases and signal decreases. Finally, just as the signal vanishes, the x polarized photon produces infinitesimal amounts of nearly pure ΨE1uy . Contour plots of the benzene basis orbitals are on file in the Symmetry` package. We pull these two out again for inspection : xAndy = Show@GraphicsRow@8cpBzE1ga, cpBzE1gb
ΨE1g HxL
ΨE1g HyL
Fig. 44.1 Excited states produced by x- and y- polarized photons
It is quite clear from these diagrams that x-polarized light maximally provokes oscillations in the x direction, but cannot provoke the orthogonal partner. The other family members, the states that lie between pure x and pure y were all shown long ago in the E1 u movie in Chapter 23, SymmetryAndQuantumMechanics.
44.4 Transition oscillations Why do we talk about oscillations in eigenstates, which are also called stationary states ? Yes, it's true, the eigenstate probability density clouds do not oscillate. But there is a time dependence that goes with every eigenstate (usually ignored). It is Ψs @x, y, zD Exp@ä HEns ÑL tD where En means eigenenergy. When you construct the probability density functions by multiplying the wave function by its own conjugate, the time dependence consumes itself and you get a stationary probability density : Ψo @x, y, zD ExpBä
570
Eno Ñ
tF Ψo @x, y, zD ExpBä
Eno Ñ
*
tF
Transition oscillations Ψo @x, y, zD2
However, apply this recipe to a state that is moving from Ψo to Ψf . When it is halfway through the quantum transition, it is a linear combination of old and new Clear@tD Ψhalfway =
1
Ψo ExpBä
Eno
2 * Ψhalfway =
1
Ψo ExpB-ä
Ñ
tF + Ψf ExpBä
Eno Ñ
2
Enf Ñ
tF + Ψf ExpB-ä
tF ;
Enf Ñ
tF ;
Construct the probability density for Ψhalfway by the usual recipe : * Ρ = Ψhalfway Ψhalfway FullSimplify
1 2
Ψ2f + Ψ2o + 2 Ψf Ψo CosB
HEnf - Eno L t Ñ
F
HEnf -Eno L . Ñ But this is exactly the Einstein's Law DE = Ñ Ω. Something is going right here!
The time dependence survived. Its angular frequency is Ω ==
For plotting purposes we would rather have 2Π t in the Cos function; we will see one whole cycle as t runs from 0 to 1. We make this change at the same time that we put in the orbitals for the A1 g ® E1 u x transition in benzene : Ψsq@t_D := EvaluateB Ρ . :Ψo ® ΨBzA2u, Ψf ® ΨBzE1ga,
HEnf - Eno L Ñ
® 2 Π>F;
The probability density Ψsq is a monster, as you might suspect. You can look at it on your own if you want to. But Mathematica loves to evaluate monster functions, and does so very quickly. So without further ado, interactive readers can see a movie of it; hard copy readers will have to make do with one frame. trTable = Table@ContourPlot@Ψsq@tD, 8x, -3, 3<, 8y, -3, 3<, Contours ® 4, ImageSize ® 100, FrameTicks ® None, ColorFunction ® BlueShadesD, 8t, 0, .95, .05
571
Symmetry Theory
Fig. 44.2 The transition oscillations in the A2 u ® E1 g halfway state
Run the movie and you will see exactly what is meant by transition oscillations. These oscillations are exactly in synch with the x- polarized oscillations of the electric field. James Clerk Maxwell deduced that accelerating charge is the one and only source or sink of radiation. As you see, quantum mechanics supports this very nicely. On your own Make a movie of the transition oscillations from A1 g to another member of the E1 u family. The direction will not be exactly parallel to x, but there is a component in that direction. That is why they are less probably excited than ΨBzE1ux.
44.5 End Notes 44.5.1 Polarization vectors Light is described most fundamentally by its vector potential, A[Ξ,Η,Ζ,t], where Ρ = 8Ξ, Η, Ζ< are the Cartesian coordinates. From this both the
electric and magnetic fields can be extracted by simple formulas. The electric field formula is E@Ξ, Η, Ζ, tD == K ReB¶t A@Ξ, Η, Ζ, tDF where K is a combination of fundamental constants. If the vector potential is a plane wave 572
End Notes
plane wave
A@Ξ, Η, Ζ, tD == A0 Λ ExpBä KΚ.Ρ - Ω t + ΦOF
The explicit phase factor Φ allows us to take the amplitude A0 pure real. Without loss of generality we may take Κ to be {0,0,Κ}. But Λ has to be perpendicular to Κ , so then Λ = 8ΛΞ , ΛΗ , 0<. In 2D graphic work below, we will use only the transverse part 8ΛΞ , ΛΗ <. The formula for the electric field is Efield = K JA0 ReB¶t JΛ Exp@ä HΚ Ζ - Ω t + ΦLDNF . 8HΚ Ζ - Ω t + ΦL ® Χ< FactorN
A0 K ImBãä Χ Ω ΛF
After taking the derivative above we replaced the wave argument k Ζ - Ω t + Φ by Χ . As Lord Rayleigh famously observed, the factor of Ω generated by taking the derivative is what makes the sky blue. The harmonic factor is Clear@HrmFctrD; HrmFctr@Λvec_D := Cos@ΧD Im@ΛvecD + Re@ΛvecD Sin@ΧD; Now you see why the field oscillates linearly in the direction of Λ if Λ is pure real; HrmFctr becomes just Λ Sin@ΧD, If Λ is complex, the answer is much more interesting. First make a normalized transverse complex vector : rndC := RandomComplex@8-1 - ä, +1 + ä
8-0.299276 - 0.946134 ä, -0.014462 + 0.122699 ä<
Look at the HrmFctr that this produces : HrmFctr@ΛD
8-0.946134 Cos@ΧD - 0.299276 Sin@ΧD, 0.122699 Cos@ΧD - 0.014462 Sin@ΧD<
This is exactly the format needed by ParametricPlot. Make a fresh Λ vector and plot as Χ runs over one cycle:
573
Symmetry Theory
1
-1
1
-1 Fig. 44.3 Elliptical polarization. Motion of the tip of the electric vector, looking into the light source.
Select the little closed cell above this figure and evaluate it a few times. It uses rndC to make a new random ellipse every time it runs. The arrow shows the sense of rotation; sometimes it goes clockwise, sometimes counterclockwise. The transverse right- and left- handed circular polarization vectors are 8Eright, Eleft< = 81, -ä< 81, ä< :HrmFctrB F, HrmFctrB F> 2 2 ::
Sin@ΧD
,-
Cos@ΧD
2
>, :
Sin@ΧD
Cos@ΧD ,
2
2
>>
2
Lest there be any misunderstanding, we plot these functions from a start on the x-axis through about 350°, ending in a blue arrowhead.
Λ
81,-ä,0<
4
Λ
Right
1
1 -1
2
Left
1
-1
81,+ä,0<
4
2
-1
1 -1
Fig. 44.4 Circular polarization. Motion of the tip of the electric vector, looking into the light source.
Here is where the names “right” and “left” come from: Point at your nose with the thumb of your right hand, fingers curled. Your thumb represents the propagation vector, so you are looking into the light source. The electric vector 574 turns in the same direction as your fingers (counterclockwise) , so the figure labelled “Right” is indeed right-handed light. Use your left hand for the other one.
End Notes
Here is where the names “right” and “left” come from: Point at your nose with the thumb of your right hand, fingers curled. Your thumb represents the propagation vector, so you are looking into the light source. The electric vector turns in the same direction as your fingers (counterclockwise) , so the figure labelled “Right” is indeed right-handed light. Use your left hand for the other one.
575
45. Two-photon tensor projections Preliminaries
45.1. The operator for two-photon processes 45.1.1 The matrix element We depend on other sources (Sakurai, Bunker, McClain and Harris) for the derivation of the two-photon operator, which applies to both two-photon absorption (TPA; two in, none out) and Raman and Rayleigh scattering (RRS; one in, one out). In this chapter we show how the two-photon operator poses a symmetry problem, and how the tools we have developed can be used to solve it. The theory was first developed by Maria Göppert-Mayer in 1931. She built on the theory of one-photon events (first order perturbation by oscillating electric field), taking it to second order to obtain the two-photon result. In TPA, the molecule is located at the intersection of two laser beams with frequencies Ωa and Ωb , and polarization vectors Λa and Λb . The amplitude AΓ,Φ for a twophoton transition (from ground state ΨΓ to final state ΨΦ ) is given by
AΓ,Φ = ÚΙ
ZΨΓ ËΛa .rËΨΙ ^ ZΨΙ Ër.Λb ËΨΦ ^ ΩΓ,Ι -Ωa
+
ZΨΓ ËΛb .rËΨΙ ^ ZΨΙ Ër.Λa ËΨΦ ^
(45.1)
ΩΓ,Ι -Ωb
where Γ, Ι, and Φ are mnemonics for ground, intermediate, and final. The sum runs over all molecular eigenstates ΨΙ ; ΩΓ,Ι is the frequency of the transition Γ®Ι; r is the Cartesian coordinate vector {x,y,z}. This state sum is symmetric for exchange of photons; if a ® b and b ® a, the first and second summands change places, but the sum is the same. We will work exclusively with the amplitude AΓ,Φ ; but never forget that the observable 2
is the rate constant for the two-photon event, proportional to
AΓ,Φ , or
when the final state is an E state with basis functions ΦEa and ΦEb the formula
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_45, © Springer Science+Business Media, LLC 2009
577
This state sum is symmetric for exchange of photons; if a ® b and b ® a, the first and second summands change places, but the sum is the same. We will work exclusively with the amplitude AΓ,Φ ; but never forget that the observable Symmetry Theory
2
is the rate constant for the two-photon event, proportional to
AΓ,Φ , or
when the final state is an E state with basis functions ΦEa and ΦEb the formula 2
becomes AΓ,ΦEa
+ AΓ,ΦEb
2
, and so forth for higher degeneracies.
We now factor the polarization vectors out of the matrix elements : AΓ,Φ = â ΛΑ .
ZΨΓ È r È ΨΙ ^ ZΨΙ È r È ΨΦ ^
. Λb +
ΩΓ,Ι - Ωa
Ι
ZΨΓ È r È ΨΙ ^ ZΨΙ È r È ΨΦ ^ Λb .
or in index notation AΓ,Φ = Λaj Λbk â
ΩΓ,Ι - Ωb
XΨΓ È rj È ΨΙ \ XΨΙ È rk È ΨΦ \ ΩΓ,Ι - Ωa
Ι
. Λa
+
XΨΓ È rk È ΨΙ \ XΨΙ È rj È ΨΦ \ ΩΓ,Ι - Ωb
where the sum over j,k is understood. It also helps to move the bra XΨΓ È and the ket ÈΨΦ \ as far outward as possible, leaving a single big operator between them
AΓ,Φ = Új,k Λaj Λbk [ΨΓ
ÚΙ K
rj ÉΨΙ ] XΨΙ È rk ΩΓ,Ι -Ωa
rk ÈΨΙ \ "XΨΙ È rj
+
ΩΓ,Ι -Ωb
O ΨΦ _
(45.2)
We need to distinguish between the operator and the matrix element. The operator is a double-struck S
Sa,b j,k =
ÚΙ K
rj ÈΨΙ \ XΨΙ È rk ΩΓ,Ι -Ωa
+
rk ÈΨΙ \ XΨΙ È rj O ΩΓ,Ι -Ωb
(45.3)
whereas the tensor matrix element (a 3 ´3 array of numbers) is a Gothic S : a,b Sa,b j,k @Γ, ΦD = ZΨΓ Ë Sj,k Ë ΨΦ ^
(45.4)
The explicit Γ,Φ dependence is usually redundant, so except when we need a,b
specific state names we write just Sj,k . Finally it is clear that the two-photon amplitude is just a matrix dotted from each side by a polarization vector. In b index notation it is Új,k Λaj Sa,b j,k Λk , or in vector notation it is
578
Two-photon operator
ATPA = Λa . Sa,b . Λb This is a good place to note that the formulae for TPA and RRS are just a little different, because the basic formalism of physics requires that annihilated photons and created photons be treated differently. In Raman, the polarization vector of the created photon b must be conjugated:
ARaman =
Λa . Sa,b . Λb
*
The Raman emission is of course an incoherent mixture of polarizations. What we really mean above is that the detector is looking through a polarization filter that passes only the pure polarization Λb . Define the two-photon matrix as a Mathematica function :
Sa_,b_ j_,k_ := â
XΨΓ È rj È ΨΙ \ XΨΙ È rk È ΨΦ \ ΩΓ,Ι - Ωa
Ι
+
XΨΓ È rk È ΨΙ \ XΨΙ È rj È ΨΦ \ ΩΓ,Ι - Ωb
8r1 ® x, r2 ® y, r3 ® z<
.
The matrix itself is not symmetric for exchange of j and k alone; its symmetry is a little more complicated: b,a Sa,b j,k == Sk,j
True
45.1.2 Proof that the matrix element is a tensor Make a harmless maneuver: insert a unit matrix at two places in the Dot product of Eq. 45.4, but write it as a rotation matrix R times its inverse:
A = Λa .IR-1 .RM.Sa,b .IR-1 .RM.Λb Regrouping we see something interesting:
A = JΛa .R-1 N.IR.Sa,b .R-1 M.JR.Λb N
It gets better if we use the transpose identity on the leftmost factor :
A = JIR-1 M .HΛa LT N.IR.Sa,b .R-1 M.JR.Λb N T
But R is a unitary matrix, so IR-1 M = R. And as the writers of Mathematica T
have so usefully pointed out, there is no need to keep track of whether vectors are row vectors or column vectors. They are just simple lists that take on row or column properties according to their position in the Dot product (left of the dot 579 Þ row ; right of the dot Þ column). So
Symmetry Theory
But R is a unitary matrix, so R-1
T
= R. And as the writers of Mathematica
are row vectors or column vectors. They are just simple lists that take on row or column properties according to their position in the Dot product (left of the dot Þ row ; right of the dot Þ column). So
A = JR.Λa N.JR.Sa,b .R-1 N.JR.Λb N
(45.5)
This expression is a scalar amplitude, invariant under symmetry transforms. But R.Λa is well known as the rotational transform of vector Λa , and similarly for Λb . Therefore the object in the middle must be the formula for rotating Sa,b by R. These objects give the same scalar A when they all transform together to a new absolute orientation in space. The rotation formula R.S .R-1 is in fact the defining property of a Cartesian tensor. Therefore, the very complicated quantum sum S is a Cartesian tensor.
45.2. Operators for tensor projection 45.2.1. The projection step by step We illustrate the projection in detail, using the x,y element of the general tensor as defined above , except that we take the state sum over Ι as understood. We must avoid setting T[x,y] to anything, so we call it Txy instead: Txy = S1,2 P2T a,b
XΨΓ È x È ΨΙ \ XΨΙ È y È ΨΦ \ -Ωa + ΩΓ,Ι
+
XΨΓ È y È ΨΙ \ XΨΙ È x È ΨΦ \ -Ωb + ΩΓ,Ι
The 1,2 subscript has brought forth the x,y element. Remember, this is only one of nine tensor elements that we could have chosen to use as the example. Below, we calculate three results labelled Txy1 to Txy3, all identical to each other. First, do a trace projection of Txy. The whole result is longer than we need to see, so we display only part P1,2T, the species A projection : Txy1 = ProjectET@Txy, "C3"DP1, 2T
580
Tensor projection operators [ΨΓ
[ΨΓ
ΨΙ _ [ΨΙ
3 y
-x + 2
2
2
[ΨΓ
3 x 2
-
-
3 x 2
3 x
3 H-Ωa + ΩΓ,Ι L
3 H-Ωa + ΩΓ,Ι L
ΨΙ _ [ΨΙ
y 2
2
y 2
2
ΨΦ _
-
y 2
ΨΦ _
XΨΓ È y È ΨΙ \ XΨΙ È x È ΨΦ \ 3 H-Ωb + ΩΓ,Ι L
+
- x2 -
ΨΙ _ [ΨΙ
y
+
3 H-Ωb + ΩΓ,Ι L
-
-
+
ΨΙ _ [ΨΙ
XΨΓ È x È ΨΙ \ XΨΙ È y È ΨΦ \ [ΨΓ
2
3 H-Ωa + ΩΓ,Ι L 3 y
- x2 -
3 x
-
3 y 2
+
ΨΦ _ +
-x +
3 H-Ωb + ΩΓ,Ι L
2
3 y 2
ΨΦ _
As expected, it is a linear combination of expressions in which x and y have been transformed by the operators of group C3 . We simplify this carefully by hand. First, several integrands are a sum of two expressions, so we rewrite them as the sum of two integrals : Txy2 = Txy1 . Xg_ È r_ + s_ È f_\ ® Xg È r È f\ + Xg È s È f\ Expand;
Interactive readers can remove the semicolon and see the rather long intermediate expression. Now all the operands are either x or y times some coefficient. We move the coefficients out in front of the integrals, after which Mathematica does a lot of cancellation : Txy3 = Txy2 . 8 Xg_ È c_ x È f_\ ® c Xg È x È f\,
Xg_ È c_ y È f_\ ® c Xg È y È f\< Expand
-
XΨΓ È y È ΨΙ \ XΨΙ È x È ΨΦ \ 2 H-Ωa + ΩΓ,Ι L
+
2 H-Ωb + ΩΓ,Ι L
-
XΨΓ È y È ΨΙ \ XΨΙ È x È ΨΦ \
XΨΓ È x È ΨΙ \ XΨΙ È y È ΨΦ \ 2 H-Ωa + ΩΓ,Ι L
XΨΓ È x È ΨΙ \ XΨΙ È y È ΨΦ \
+
2 H-Ωb + ΩΓ,Ι L
It is done. The trace projection of T[x,y]under group C3 has only four terms.
581
Symmetry Theory
45.3 Self-purifying tensor elements Now think what we did. We defined T@x, yD
YΨΓ ÉxÉΨΙ ] XΨΙ ÈyÈΨΦ \ -Ωa +ΩΓ,Ι
+ (45.6)
YΨΓ ÉyÉΨΙ ] XΨΙ ÈxÈΨΦ \ -Ωb +ΩΓ,Ι
(with sum over Ι understood) and projected it, giving an answer with four terms like
XΨΓ ÈÈΨΙ \ XΨΙ ÈÈΨΦ \ . -Ω +ΩΓ,Ι
The quantum sum T[x,y] is incredibly difficult to
compute, but it has one simple feature: it is linear in the Cartesian operators. In the preliminaries we make special rules for the function T[u,v](where u and v are Cartesian variables x,y,z ) that makes it automatically linear in its Cartesian variables. It uses a test that identifies the Cartesian variables: CartesianQ[u_]:= (u === x || u === y || u === z) Here is a copy of the definitions that give T its linear properties : T[a_ + b_, c_] := T[a, c] + T[b, c]; T[a_, c_ + d_] := T[a, c] + T[a, d]; T[a_ *u_?CartesianQ, v_] := a*T[u, v]; T[u_, b_*v_?CartesianQ] := b*T[u, v]; These rules are active if you ran the preliminaries, so observe how T automatically simplifies itself : T@a x + b y, c x + d yD a c T@x, xD + a d T@x, yD + b c T@y, xD + b d T@y, yD a,b
If we project T[i,j] as a surrogate for Si,j , each summand will automatically expand itself to a linear combination of the 9 possible simple objects. Then Mathematica will automatically perform cancellations, producing an object that cannot be longer than 9 terms. Here is an example: ProjectET@T@x, yD, "C3"D ::A,
1 2
T@x, yD -
1 T@y, xD>, 2 ,
582
Self-purifying elements :Ea,
1
ä T@x, xD +
4
:Eb, -
1
T@x, yD +
4 1
ä T@x, xD +
4
1
T@y, xD -
4 1
T@x, yD +
4
1
ä T@y, yD>,
4 1
T@y, xD +
4
1
ä T@y, yD>>
4
All the work of linear expansion has been done automatically.
45.4. Operators for tensor projection 45.4.1. Projection of the whole tensor This means we can easily do the whole tensor of T-functions at once. In the preliminaries we set up a tensor of nine T functions: Tij =
T@x, xD T@x, yD T@x, zD T@y, xD T@y, yD T@y, zD ; T@z, xD T@z, yD T@z, zD
so we just project the whole Tij tensor. We make it a little slicker by defining a specialized projection operator called TraceProjectTij. It will be fully explained below. It consists of perfectly ordinary trace projection, plus a filter that gets rid of any all-zero projections.
45.4.2. The simplest example As our first demo we do a very simple case, group C2 , with only two species. It has only one transform, rotation about z by half a turn. But it gives a non-trivial trace projection: trPrjC2 = TraceProjectTij@"C2"D
8C2, 88A, 88T@x, xD, T@x, yD, 0<, 8T@y, xD, T@y, yD, 0<, 80, 0, T@z, zD<<<, 8B, 880, 0, T@x, zD<, 80, 0, T@y, zD<, 8T@z, xD, T@z, yD, 0<<<<<
This is easier to read in a Grid :
8A, GridForm@trPrjC2P2, 1, 2TD< 8B, GridForm@trPrjC2P2, 2, 2TD< :A,
T@x, xD T@y, xD 0
T@x, yD T@y, yD 0
0 0 T@z, zD
>
583
Symmetry Theory
:B,
0 0 T@z, xD
0 0 T@z, yD
T@x, zD T@y, zD 0
>
Now you can see at a glance that the two projected parts add up to the original. Those elements that are unchanged by the two-fold rotation about z are in species A; those that change sign are in species B. All groups work out pretty much like this, but with many more complications, of course.
45.4.3. Trace projection, TraceProjectTij Do this again with D3 h , which has two true 2D species. As always, the 2D species name is E, or something anchored on an E: BoxedCharacterTable@"D3h"D D3h
1
2
3
1
2
3
A1¢
E C3 C2 Σh S3 Σv 1 1 1 1 1 1
A2¢
1
E¢
2 -1
1 -1 0
1
Basis functions 8H x2 + y2 L, H z2 L<
1 -1 9I y I3 x2 - y2 M M, H Iz L=
2 -1
A1¢¢
1
1
A2¢¢
1
1 -1 -1 -1
E¢¢
2 -1
0
1 -1 -1 -1
0 -2
¬ Class populations
1
1 0
:K
x O, y
1 2
Ix2 - y2 M
9I x Ix2 - 3 y2 M z M= xy
>
8H z L< xz Ix :K O, K O> yz Iy
First do a trace projection: tracePrjD3h = TraceProjectTij@"D3h"D
584
Two-photon tensor patterns :D3h, ::A1¢ , :: :0,
1 2
1 2
1
HT@x, xD + T@y, yDL, 0, 0>,
1 2
HT@x, yD - T@y, xDL, 0>,
H-T@x, yD + T@y, xDL, 0, 0>, 80, 0, 0<>>,
:E¢ , :: :
2
HT@x, xD + T@y, yDL, 0>, 80, 0, T@z, zD<>>,
:A2¢ , ::0, :
1
1 2
HT@x, xD - T@y, yDL,
HT@x, yD + T@y, xDL,
1
1 2
HT@x, yD + T@y, xDL, 0>,
H-T@x, xD + T@y, yDL, 0>,
80, 0, 0<>>, 8E¢¢ , 880, 0, T@x, zD<, 2
2
80, 0, T@y, zD<, 8T@z, xD, T@z, yD, 0<<<>>
You must look carefully to see that several elements above are the same, or closely related. To help with this we need a routine that scans the whole tensor, picking out the first linear combination it comes to (that would be 1 T@x, xD + 1 T@y, yD ), and then searches out all other instances of this same 2 2 expression and replaces them all by some single letter. Then it continues assigning letters to expressions until all the tensor elements have been replaced by some single letter. This will let us see the “pattern” of the tensor at a glance. Such an operator is in the Preliminaries under the name SymbolizeTij. It takes its symbols from two lists prepared in the Preliminaries: LatUC (Latin upper case, for expressions with no ä in them) and GrkLC (Greek lower case for expressions that do contain ä). When it finds a complex expression, it divides it into a real part a and imaginary part b, and makes up rules that include a+äb ® Α
Α*
a-äb ®
and
When used with a symbolizer that automatically detects and reports proportionalities, this gives the complex notation that humans expect. Watch it work on the raw projections displayed above : traceMatsD3h = Transpose@tracePrjD3hP2TDP2T; SymbolizeTij@traceMatsD3h, LatUC, GrkLCD GridList Size@8D :
A 0 0
0 A 0
0 0 B
,
0 -C 0
C 0 0
0 0 0
,
D F 0
F -D 0
0 0 0
,
0 0 J
0 0 K
G H 0
>
These are the S tensors, with all interior matrix elements XΨΓ È x È ΨΙ \ and
XΨΙ È y È ΨΦ \ etc. done symbolically, and the whole sum over all intermediate states performed symbolically. The numbers A,B,… may or may not be computable by quantum theorists, but they can certainly be measured by spectroscopists. So these tensor “patterns” are the meeting point of theory and 585 experiment.
These are the S tensors, with all interior matrix elements XΨΓ È x È ΨΙ \ and XΨΙ È y È ΨΦ \ etc. done symbolically, and the whole sum over all intermediate
Symmetry Theory
computable by quantum theorists, but they can certainly be measured by spectroscopists. So these tensor “patterns” are the meeting point of theory and experiment. We see only Latin capitals, so the trace projections have no explicit ä in them. Compare to the raw tensors above to see that symbolization worked correctly. After you symbolize, you may want to know what the operators are. Just call up a quantity named Symbolizations that was created while SymbolizeTij was operating. Here they are : Symbolizations Column : 12 T@x, xD +
1 2
8T@z, zD ® B<
T@y, yD ® A>
: 1 T@x, yD -
1 2
T@y, xD ® C>
1 2
T@y, yD ® D>
1 2
T@y, xD ® F>
: 12 T@x, xD 2
:1 2
T@x, yD +
8T@x, 8T@y, 8T@z, 8T@z,
zD ® G< zD ® H< xD ® J< yD ® K<
Symbolizations is overwritten each time SymbolizeTij runs, so it must be preserved immediately if you want to use it.
45.4.4. Detailed projection, DetailedProjectTij When a group has an E species, the trace projection gives only the sum of the two detailed projections. To see them individually, you must do a detailed projection. The operator for this has a lot to do. First it has to make a full representation of the group, and the basis it uses for this is an important point. It always uses the first basis listed in the character table, which in the case of species E¢ of D3 h is {x,y}. But the algorithm automatically transforms basis {a,b} into {a + ä b,a - ä b}. So in this case it uses {x + ä y,x - ä y}. The rep is quickly found by MakeRepPoly, and it is used by ProjectED[expr,rep,component,"D3h"] with components 1 and 2. It always appends letters a and b to the E-type species name to form the names of the detailed projections that are found. Apply it and display only the E¢ species from the result: detailedPrjD3h = DetailedProjectTij@tracePrjD3hD; detailedPrjD3hP2, 3T
586
Two-photon tensor patterns ::E¢ a, :: 1 :
4 1 4 1
1 4
HT@x, xD - ä HT@x, yD + T@y, xDL - T@y, yDL,
Hä T@x, xD + T@x, yD + T@y, xD - ä T@y, yDL, 0>, Hä T@x, xD + T@x, yD + T@y, xD - ä T@y, yDL, H-T@x, xD + ä HT@x, yD + T@y, xDL + T@y, yDL,
0>, 80, 0, 0<>>, 4
:E¢ b, :: 1 :
4 1 4 1
1 4
HT@x, xD + ä HT@x, yD + T@y, xD + ä T@y, yDLL,
H-ä T@x, xD + T@x, yD + T@y, xD + ä T@y, yDL, 0>, H-ä T@x, xD + T@x, yD + T@y, xD + ä T@y, yDL, H-T@x, xD - ä HT@x, yD + T@y, xDL + T@y, yDL,
0>, 80, 0, 0<>>> 4
The E¢a projection is from component 1; E¢b is from 2. That is a lot of output to wade through. Symbolization is now quite essential.
45.4.5. Symbolization by SymbolizeProjectionTij How SymbolizeProjectionTij works Our projections contain a group name and species names that must be protected against symbolization, so we have written a useful operator that separates names from tensors, send the tensors to SymbolizeTij, makes a labelled copy (not overwritable) of the Symbolizations, then finally restores the names and returns the symbolized projection. Click into the Preliminaries read it; or just watch it work : entryD3h = SymbolizeProjectionTij@detailedPrjD3hD 8D3h, 88A1¢ , 88A, 0, 0<, 80, A, 0<, 80, 0, B<<<, 8A2¢ , 880, C, 0<, 8-C, 0, 0<, 80, 0, 0<<<, 88E¢ a, 88Α, ä Α, 0<, 8ä Α, -Α, 0<, 80, 0, 0<<<, 8E¢ b, 88Α* , -ä Α* , 0<, 8-ä Α* , -Α* , 0<, 80, 0, 0<<<<, 88E¢¢ a, 880, 0, Β<, 80, 0, -ä Β<, 8Γ, -ä Γ, 0<<<, 8E¢¢ b, 880, 0, Β* <, 80, 0, ä Β* <, 8Γ* , ä Γ* , 0<<<<<<
587
Symmetry Theory
The E¢a and E¢b results collapsed to a single line each. It preserved Symbol izations under the name SymbolRules["D3h"] : SymbolRules@"D3h"D Column :A ®
1 2
T@x, xD +
1 2
T@y, yD>
:C ®
1 2
T@x, yD -
1 2
T@y, xD>
T@x, xD -
1 4
ä T@x, yD -
1 2
T@x, zD +
1 2
ä T@y, zD>
1 2
T@z, xD +
1 2
ä T@z, yD>
8B ® T@z, zD< :Α ® :Β ® :Γ ®
1 4
1 4
ä T@y, xD -
1 4
T@y, yD>
Cyclic axis permutation symmetry The tetrahedron has a three-fold symmetry rotation about the {1,1,1} axis. We bring it out as a symmetry rule: Thread@8x, y, z< ® AxialRotation@81, 1, 1<, -2 Π 3D.8x, y, z
So this rotation is just a cyclic permutation of axes. In group T, this is rule 2: SymmetryRules@"T"DP2T 8x ® y, y ® z, z ® x<
How many other groups also possess this rule? Select@GroupCatalog, Not@FreeQ@SymmetryRules@ðD, 8x ® y, y ® z, z ® x
All the Platonic groups have it. As we argued in detail in Chapter 39 (Matrix elements) integrals are invariant under a unitary transformation of the entire integrand. So if the matrix element T@x, xD =
XΨΓ È x È ΨxΙ \ XΨxΙ È x È ΨΦ \ -Ωa + ΩΓ,Ι
+
XΨΓ È x È ΨxΙ \ XΨxΙ È x È ΨΦ \ -Ωb + ΩΓ,Ι
(where ΨΓ and ΨΦ are totally symmetric) is subjected to axis permutation (including axis permutation in the intermediate wave functions), its value does not change, but its formula becomes
588
Two-photon tensor patterns YΨΓ É y É ΨΙ ] YΨΙ É y É ΨΦ ] y
y
-Ωa + ΩΓ,Ι
YΨΓ É y É ΨΙ ] YΨΙ É y É ΨΦ ] y
+
y
-Ωb + ΩΓ,Ι
But this is exactly T[y,y]. This means that T[x,x] = T[y,y], and similarly, T[y,y] = T[z,z] in the Platonic groups. A similar thing happens in the off-diagonal elements. The formula for the x,y element is XΨΓ È x È ΨxΙ \ YΨxΙ É y É ΨΦ ] x,y
-Ωa + ΩΓ,Ι
YΨΓ É y É ΨΙ ] YΨΙ É x É ΨΦ ] y
+
y
y
y,z
-Ωa + ΩΓ,Ι x,y ΨΦ
x,y
-Ωb + ΩΓ,Ι
Subject this to axis permutation:
YΨΓ É y É ΨΙ ] YΨΙ É z É ΨΦ ]
y
XΨΓ È z È ΨzΙ \ YΨzΙ É y É ΨΦ ] y,z
+
-Ωb + ΩΓ,Ι
y,z ΨΦ
where the final states and are degenerate. But the operator here is exactly the operator of T[y,z], so after integration T[x,y]= T[y,z]; and similarly T[y,z]= T[z,x]. The same argument shows T[y,x]= T[z,y] = T[x,z]. However, because the denominators are generally different, it is not true that T[x,y]º T[y,x], etc. Here is a rule that embodies these results: xyzPermSymmTij = 8 T@x, xD ® PP, T@y, yD ® PP, T@z, zD ® PP, T@x, yD ® QQ, T@y, zD ® QQ, T@z, xD ® QQ, T@y, xD ® RR, T@z, yD ® RR, T@x, zD ® RR<;
SymbolizeProjectionTij applies this to all appropriate groups. The names PP, etc., are just dummies and are replaced by single letters when submitted to the final symbolization routine. Another axis permutation symmetry Group D2 d has a dihedral reflection between the x and y axes, so this reflection swaps x and y while leaving z alone: {x ® y,y ® x,z ® z}. Do any other groups have this symmetry? Select@GroupCatalog, Not@FreeQ@SymmetryRules@ðD, 8x ® y, y ® x, z ® z
Note that O and Oh have both symmetries. Therefore we must divide the axis permutation groups into three types: nonsquare Platonic (I, T, Td , Th ), square Platonic (O, Oh ) , and square nonPlatonic ( C4 v , D2 d , D4 h , D6 d ). Each of these has its own set of axis permutation symmetries. The nonsquare Platonic rules have already been given. The square NonPlatonic rules are
589
Symmetry Theory
xyPermSymmTij = 8 T@x, xD ® PP, T@y, T@x, yD ® QQ, T@y, T@z, xD ® RR, T@z, T@x, zD ® SS, T@y,
yD ® PP, xD ® QQ, yD ® RR, zD ® SS<;
and the rules for the square Platonics are
xyAndxyzPermSymmTij = 8 T@x, xD ® PP, T@y, yD ® PP, T@z, zD ® PP, T@x, yD ® QQ, T@y, zD ® QQ, T@z, xD ® QQ, T@y, xD ® QQ, T@z, yD ® QQ, T@x, zD ® QQ<;
SymbolizeProjectionTij applies these rules to all appropriate groups. By our orientation rules, no other axis permutation symmetries will exist.
45.4.6. The combined operator MakeRawEntryTij The three operators above ( TraceProjectTij, DetailedProjectTij, and SymbolizeProjectionTij ) are conveniently combined by a little driver called MakeRawEntryTij[groupName]. Click into the Preliminaries to read it, then watch it work: entryC3 = MakeRawEntryTij@"C3"D
8C3, 88A, 88A, B, 0<, 8-B, A, 0<, 80, 0, C<<<, 8Ea, 88Α, ä Α, Β<, 8ä Α, -Α, -ä Β<, 8Γ, -ä Γ, 0<<<, 8Eb, 88Α* , -ä Α* , Β* <, 8-ä Α* , -Α* , ä Β* <, 8Γ* , ä Γ* , 0<<<<<
While SymbolizeProjectionTij was operating, it made the Symbol Rules for this group: SymbolRules@"C3"D ::A ® :B ® :Α ® :Β ®
590
1 2 1 2 1 4 1 2
T@x, xD + T@x, yD T@x, xD T@x, zD +
1 T@y, yD>, 2 1 2 1 4 1 2
T@y, xD>, 8C ® T@z, zD<, ä T@x, yD -
1
ä T@y, xD -
4
ä T@y, zD>, :Γ ®
1 T@y, yD>, 4
1 2
T@z, xD +
1 2
ä T@z, yD>>
Two-photon tensor patterns
45.4.7. The operator TPTdisplay The output of SymbolizeProjectionTij is still a little hard to read for non-Mathematica people. So we have written an operator TPTdisplay that cleans them up like a typesetter might. Its input is a list of raw table entries and a style specification. Only fanatics will open the preliminaries to see how it works. Here is an example: MakeTijdisplay@8entryD3h<, 8FontFamily ® "Arial", 7
D3h A
0
0
0
C
0
0
A
0
-C
0
0
0
0
B
0
0
0
:
0
0
Β
0
0
-ä Β
Γ
-ä Γ
0
,
:
Α
äΑ
0
äΑ
-Α
0
0
0
0
*
0
0
Β
0
0
ä
*
ä Γ*
Γ
Β*
*
0
-ä Α*
-ä Α* - Α*
0
0
0
Α
,
0
>
>
0
The name of the group is shown in boldface, followed by a list of species that have nonzero tensor projections; then on the next line are the respective patterns, in grids that help the eye. Degenerate patterns are bracketed together. All-zero patterns are omitted. The patterns of many groups are identical. So the display generator also searches the raw entries input list for cases that have identical patterns, and groups them together, printing the patterns only once. This shortens the final output considerably.
45.5 Two-photon tensor projection table 45.5.1. Make all non-zero table entries (no styling) We will now do all our tabulated groups in one fell swoop. GroupCatalog
591
Symmetry Theory 8C1, C2, C2h, C2v, C3, C3h, C3v, C4, C4h, C4v, C5, C6, C6h, C6v, Ch, Ci, D2, D2d, D2h, D3, D3d, D3h, D4, D4d, D4h, D5, D5d, D5h, D6, D6d, D6h, I, O, Oh, S4, S6, S8, T, Td, Th<
Apply MakeRawEntryTij to this long list of group names. You will see a lot of flashing as it works. It is trying to display the name of the group it is working on, but most flash by too quickly to read. Only the larger groups take a perceptible time; in particular I is quite slow (be patient; it will finish). Be aware that all this is done in infinite precision, even the groups with five-fold axes. allRaw = MakeRawEntryTij@GroupCatalogD; Look at just one of the 40 group results : allRawP25T
8D4h, 88A1g, 88A, 0, 0<, 80, A, 0<, 80, 0, B<<<, 8A2g, 880, 0, 0<, 80, 0, 0<, 80, 0, 0<<<, 8B1g, 880, 0, 0<, 80, 0, 0<, 80, 0, 0<<<, 8B2g, 880, C, 0<, 8C, 0, 0<, 80, 0, 0<<<, 88Ega, 880, 0, Α<, 80, 0, Α* <, 8Β, Β* , 0<<<, 8Egb, 880, 0, Α* <, 80, 0, Α<, 8Β* , Β, 0<<<<<<
592
Table of two-photon tensors
45.5.2. Table of two-photon tensor patterns All that is left is the display operator MakeTijdisplay. It has already been described, so we just use it : MakeTijdisplay@allRaw, 8FontFamily ® "Arial", 8
C1
8Ag<
Ci A
B
C
D
F
G
H
J
K 8A, B<
C2
8Ag, Bg<
C2h
8A, B<
Ch A
B
0
0
C 0
0
G
D
0
0
F
0
0
H
J
K
0
8A1 , A2, B1, B2<
C2v
8A, B1, B2, B3<
D2
8Ag, B1g, B2g, B3g<
D2h A
0
0
0
D
0
0
0
G
0
0
0
B
0
F
0
0
0
0
0
0
0
J
0
0
C
0
0
0
H
0
0
0
K
0
C3 S6
0
8A, Ea, Eb<
8Ag, Ega, Egb<
A
B
0
Α
äΑ
Β
Α*
-B
A
0
äΑ
-Α
-ä Β
-ä Α*
0
0
C
Γ
-ä Γ
0
Γ*
-ä Α* Β* - Α* ä Β* ä Γ* 0
593
Symmetry Theory ¢¢ 9A¢ , E¢a , E¢b , E¢¢ a , Eb =
C3h A
B
0
Α
äΑ
0
-B
A
0
äΑ
-Α
0
0
0
C
0
0
0
Α*
0
0
0
Β
0
0
-ä Α*
-ä Α* - Α*
0
0
0
-ä Β
0
0
0
0
0
Γ
-ä Γ
0
Γ*
ä Γ*
äΑ
Β
ä
0
8A1, A2, 8Ea, Eb<<
D3
8A1g, A2g, 8Ega, Egb<<
D3d 0
0
0
C
:
0
0
A
0
-C
0
0
0
0
B
0
0
0
Α äΑ
-Α
-ä Β
Γ
-ä Γ
0
*
, -ä Α Γ*
8Ag, Bg, Ega, Egb<
C4h
8A, B, Ea, Eb<
S4 A
B
0
D
F
0
0
0
Α
0
0
-B
A
0
F
-D
0
0
0
äΑ
0
0
0
*
0
0
C
0
0
Β äΒ
0
Β
-ä
Α*
-ä Α* *
Β
0
8A1, A2, B1, B2, 8Ea, Eb<<
C4v
8A1 , A2 , B1 , B2 , 8Ea, Eb<<
D2d
8A1g, A2g, B1g, B2g, 8Ega, Egb<<
D4h 0
0
0
0
0
0
0
0
0
C
0
0
A
0
0
0
0
0
0
0
C
0
0
0
0
B
0
0
0
0
0
0
0
0
0
594
-ä Α* Β* - Α* ä Β* > ä Γ* 0
Α*
8A, B, Ea, Eb<
C4
A
Β*
8A1, A2, 8Ea, Eb<<
C3v
A
Β*
:
0
Α
0
0
*
Α
Β
Β*
0
0
,
0
0
Α*
0
0
Α
Β*
Β
0
>
Table of two-photon tensors 8A, E1a, E1b, E2a, E2b<
C5
8A, E1a, E1b, E2a, E2b<
C6
8Ag, E1ga, E1gb, E2ga, E2gb<
C6h A
B
0
0
0
Α
-B
A
0
0
0
äΑ
0
0
C
Β äΒ
0
0
Α*
0 0
0
Β*
-ä
äΓ
0
-ä Α
äΓ
-Γ
0
-ä Γ
0
0
0
0
0
Β*
0
0
0
9A1 g , A2 g , 9E1 g a, E1 g b=, 9E2 g a, E2 g b==
D5d
8A1, A2, 8E1a, E1b<, 8E2a, E2b<<
D6
8A1g, A2g, 8E1ga, E1gb<, 8E2ga, E2gb<<
D6h A
0
0
0
C
0
0
A
0
-C
0
0
0
0
B
0
0
0
Γ
-ä Γ -Γ
0
0
0
0
:
Γ*
0
-ä Γ
,
äΓ
*
0
0
Α
0
0
-ä Α
Β
-ä Β
0
ä Γ* - Γ*
0
0
0
0
0
,
0
0
0
0
Β*
ä
ä Α* > Α*
Β*
0
>
9A¢1 , A¢2 , 8E¢ a, E¢ b<, 8E¢¢ a, E¢¢ b<=
D3h 0
0
0
C
A
0
-C
0
0
0
0
B
0
0
0
0
0
Β
0
0
-ä Β
Γ
-ä Γ
0
,
:
0
0
:
0
8A1, A2, 8E1a, E1b<, 8E2a, E2b<<
D5
A
*
-ä Γ* - Γ*
8A1, A2, 8E1a, E1b<, 8E2a, E2b<<
C6v
:
Γ*
Γ *
Α
-Α
0
0
0
0
0
0
0
Γ
äΓ
Β*
ä *
Α*
0
äΑ
0 *
äΑ
Β*
*
, -ä Α 0
-ä Α* - Α*
0
0
0
0
>
>
0
595
Symmetry Theory
D4
8A1, A2, B1, B2, 8Ea, Eb<<
A
0
0
0
C
0
D
0
0
0
A
0
-C
0
0
0
-D
0
0
0
B
0
0
0
0
0
0
0
F
0
F
0
0
0
0
0
0
Α
0
0
-ä Α
Β
-ä Β
0
A
0
0
0
C
0
0
A
0
-C
0
0
0
0
B
0
0
0
0
0
Β
0
0
-ä Β
Γ
-ä Γ
0
0
0
Β*
ä
ä Α* > Α*
Β*
0
:
,
Α
-ä Α
0
-ä Α
-Α
0
0
0
0
0
0
Β*
0
0
>
Γ*
ä Γ*
ä
Β*
Α*
, ä Α*
ä Α* - Α*
0
0
0
0
0
>
0
8A1, A2, 8E2a, E2b<, 8E5a, E5b<<
D6d A
0
0
0
0
0
0
A
0
0
0
0
0
0
B
0
0
0
0
0
Β
0
0
Β*
Γ
*
:
0
¢¢ 9A¢1 , A¢2 , 9E¢2 a, E¢2 b=, 9E¢¢ 1 a, E1 b==
D5h
:
,
0
8A1, A2, 8E2a, E2b<, 8E3a, E3b<<
D4d
I
:
0
Γ
,
:
C
0
-Α
0
0
0
0
0
0
Β*
0
0
Β
*
Γ
0
Γ
0
Α C
,
>
-Α
C
0
C
Α
0
0
0
0
0
B
0
,
-B
0
0
0
0
0
>
8A, 8T1a, T1b, T1c<, 8Ha, Hb, Hc, Hd, He<<
:
A
0
0
0
A
0
0
0
A
0
0
0
0
0
0
0
0
0
:
596
0
0
0
0
0
B
0
-B
0
,
,
0
0
C
0
0
0
C
0
0
,
0
0
-B
0
0
0
B
0
0
0
0
0
0
0
C
0
C
0
,
0
C
0
C
0
0
0
0
0
>
,
0
0
0
0
0
0
0
0
0
>
Table of two-photon tensors 8A1, 8Ea, Eb<, 8T1a, T1b, T1c<, 8T2a, T2b, T2c<<
O
:
A
0
0
A
0
0
0
A
0
0
0
0
0
B
0
-B
0
: :
0
0
C
0
C
0
0
0
0
0
0
0
0
0
0
0
0
0
0
,
,
,
0
0
0
0
0
0
0
0
0
0
0
-B
0
0
0
B
0
0
0
0
0
0
0
C
0
C
0
>
0
B
0
-B
0
0
0
0
0
0
0
C
0
0
0
C
0
0
,
,
>
>
8A1g, 8Ega, Egb<, 8T1ga, T1gb, T1gc<, 8T2ga, T2gb, T2gc<<
Oh
8A1, 8Ea, Eb<, 8T1a, T1b, T1c<, 8T2a, T2b, T2c<<
Td
:
A
0
0
0
A
0
0
0
A
0
0
0
0
0
0
0
0
0
: :
0
B
0
B
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
,
,
,
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
,
0
0
0
0
0
B
0
B
0
>
0
,
>
0
0
B
0
0
0
B
0
0
>
8A, E1a, E1b, E2a, E2b, E3a, E3b<
S8 A
B
0
0
0
Α
0
0
-Α
-B
A
0
0
0
Β
0
0
-Β
0
0
C
Γ
∆
0
-Γ
-∆
0
0
0
0
D
0
0
D
0
0
0
F
0
0
F
0
G
H
0
G
H
0
¶
-ä ¶
0
-ä ¶
-¶
0
0
0
0
¶* *
ä¶ 0
ä ¶* - ¶* 0
597
Symmetry Theory 8A1, Ea, Eb, 8Ta, Tb, Tc<<
T Th
8Ag, Ega, Egb, 8Tga, Tgb, Tgc<<
A
0
0
0
0
0
0
0
0
0
A
0
0
0
0
0
0
0
0
0
A
0
0
0
0
0
0
:
0
0
0
0
0
B
0
C
0
0
0
C
0
0
0
B
0
0
,
,
0
B
0
C
0
0
0
0
0
>
After each group was symbolized, its Symbolizations were given the name SymbolRules[gp], before the next SymbolizeProjectionTij overwrote it. You can look at any of them you want: SymbolRules@"D2h"D
88A ® T@x, xD<, 8B ® T@y, yD<, 8C ® T@z, zD<, 8D ® T@x, yD<, 8F ® T@y, xD<, 8G ® T@x, zD<, 8H ® T@z, xD<, 8J ® T@y, zD<, 8K ® T@z, yD<<
45.6 Axis permutation forbiddenness Some of the results for the Platonic groups are quite surprising, and seem to be a new discovery. Here we review one of them step by step. Look at the detailed projection of species Ea of group T: tracePrj = TraceProjectTij@"T"D; detPrjTEa = DetailedProjectTij@tracePrjDP2, 2T :Ea, ::
1
T@x, xD -
3
1
0, 0>, :0, 1
T@y, yD -
ä T@y, yD
6
T@z, zD -
1
T@x, xD +
6
6
2
ä T@x, xD 2
3
-
1 6
2 3 ä T@x, xD 2
ä T@z, zD
-
1
T@z, zD +
+
2
1
T@y, yD -
1
ä T@y, yD
1
3
2
,
3
3
3
, 0>, :0, 0, -
T@y, yD +
ä T@z, zD
6
+
3
T@x, xD -
6 T@z, zD>>> 3
This is a nice non-zero result, and was not filtered out by the all-zero filter in TraceProjectTij. Now put in the axis permutation symmetry: detPrjTEa . xyzPermSymmTij
8Ea, 880, 0, 0<, 80, 0, 0<, 80, 0, 0<<<
This is a big surprise. It appears that in group T the transition A ® Ea is forbidden. All the published projections of two-photon or Raman tensors (including 598 our own), done laboriously by hand forty or more years ago, failed to pick this up.
Axis permutation forbiddenness
This is a big surprise. It appears that in group T the transition A ® Ea is forbidden. All the published projections of two-photon or Raman tensors (including our own), done laboriously by hand forty or more years ago, failed to pick this up. On your own Do the same thing for species Eb. Then do Ega and Egb in groups Th , and do the E species in O, Oh and Td , and the H species of group I. You will find surprising vanishings in all of them. Species H of I is particularly weird, as only two of its five components vanish.
45.7 Alternative forms of the tensors The tensor patterns that you get by the projection process depend on the representation that you use in detailed projection. For instance in group D3 , species E, one person might say that the degenerate patterns are :
D 0 0
0
0
-D F G
,
0
H
J
H
0
0
K
0
0
0
>
while another insists that this is wrong and the true answer is :
Α
äΑ
Β
äΑ
-Α
-ä Β
Γ
-ä Γ
0
Α*
,
*
-ä Α Γ*
-ä Α* Β* - Α* ä Β* > ä Γ* 0
But both would be correct. Remember, these are just amplitudes. It is just that the first person used a rep based on {x,y}, while the second used a rep based on {x + ä y,x - ä y}. When they calculate an intensity, each using his own tensor amplitude pattern, they get physically correct answers. This is a basic property of quantum mechanics. Only intensities are observable; amplitudes are not observable and many different amplitudes can give the same intensity.
599
46. Three-photon tensor projections Preliminaries
46.1 The operator for three-photon processes 46.1.1 The matrix element This chapter is structured exactly like Chapter 45 (TwoPhotonProjections), so we will close some sections that are very similar the the corresponding section in Chapter 45. They may be read from CD if you want to see them explicitly. One-photon processes were elucidated by first order perturbation theory; twophoton processes, by second order; now three-photon processes, by third order perturbation theory. These processes include simultaneous three-photon absorption and two-in, one-out up-conversion processes, like frequency summing, with or without conservation of photon energy. The amplitude A for a two-photon transition (from ground state ΨΓ to final state ΨΦ ) is given by an analog of Eq.
AΓ,Φ = ÚΑ,Β
45.1 :
ZΨΓ ËΛa .rËΨΑ ^ ZΨΑ Ër.Λb ËΨΒ ^ ZΨΒ Ër.Λc ËΨΦ ^ IΩΓ,Α -Ωa M
IΩΓ,Β -Ωb M
ZΨΓ ËΛb .rËΨΑ ^ ZΨΑ Ër.Λc ËΨΒ ^ ZΨΒ Ër.Λa ËΨΦ ^ IΩΓ,Α -Ωb M
IΩΓ,Β -Ωc M
IΩΓ,Α -Ωc M
IΩΓ,Β -Ωa M
+ +
H46.1L
ZΨΓ ËΛc .rËΨΑ ^ ZΨΑ Ër.Λa ËΨΒ ^ ZΨΒ Ër.Λb ËΨΦ ^
where Γ, Α, Β, and Φ index states of the molecule. This matrix element is written for the simultaneous absorption of three photons. Usually Γ is the ground state; Φ is the final state, and Α and Β must run over all states of the molecule. In photon summing processes, Γ and Φ both stand for the ground state, so that the subject molecule makes only a transient excursion out of the ground state while the frequency sum generation process is going on. The tensor appears when the polarization vectors Λa , Λb , and Λc are factored out of the scalar expression above. Converting the Λn .r expressions to explicit index
the formula becomes
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_46, © Springer Science+Business Media, LLC 2009
601
The tensor appears when the polarization vectors Λa , Λb , and Λc are factored out Symmetry Theory of the scalar expression above. Converting the Λn .r expressions to explicit index notation, the formula becomes
AΓ,Φ = â â Λai Λbj Λgk Α,Β i,j,k
XΨΓ È ri È ΨΑ \ XΨΑ È rj È ΨΒ \ XΨΒ È rk È ΨΦ \ IΩΓ,Α - Ωa M
IΩΓ,Β - Ωb M
+
XΨΓ È rj È ΨΑ \ XΨΑ È rk È ΨΒ \ XΨΒ È ri È ΨΦ \ IΩΓ,Α - Ωb M
IΩΓ,Β - Ωc M
H46.2L
+
XΨΓ È rk È ΨΑ \ XΨΑ È ri È ΨΒ \ XΨΒ È rj È ΨΦ \ IΩΓ,Α - Ωc M
IΩΓ,Β - Ωa M
where the tensor operator is the analog of Eq. 45.2 :
Si,j,k = â a,b,c
Α,Β
XΨΓ È ri È ΨΑ \ XΨΑ È rj È ΨΒ \ XΨΒ È rk È ΨΦ \ IΩΓ,Α - Ωa M
IΩΓ,Β - Ωb M
XΨΓ È rj È ΨΑ \ XΨΑ È rk È ΨΒ \ XΨΒ È ri È ΨΦ \ IΩΓ,Α - Ωb M
IΩΓ,Β - Ωc M
+
+
H46.2L
XΨΓ È rk È ΨΑ \ XΨΑ È ri È ΨΒ \ XΨΒ È rj È ΨΦ \ IΩΓ,Α - Ωc M
IΩΓ,Β - Ωa M
It is traditional to use a capital S (meaning StateSum) for this quantity. As before, the double-struck S above is the operator and the Gothic S below is the transition amplitude, the matrix element between ground (Γ) and final (Φ) states :
Sa,b,c i,j,k @Γ, ΦD =
H46.3L
ZΨΓ Ë Si,j,k Ë ΨΦ ^ a,b,c
In the preliminaries, we declare a Notation that prevents the superscripts on S from being interpreted as a strange kind of power. Therefore, we can use them as function arguments: Clear@SD;
Sa_,b_,c_ i_,j_,k_ :=
XΨΓ È ri È ΨΑ \ XΨΑ È rj È ΨΒ \ XΨΒ È rk È ΨΦ \ IΩΓ,Α - Ωa M
IΩΓ,Β - Ωb M
+
+
602
Three-photon operator
XΨΓ È rj È ΨΑ \ XΨΑ È rk È ΨΒ \ XΨΒ È ri È ΨΦ \ IΩΓ,Α - Ωb M
IΩΓ,Β - Ωc M
IΩΓ,Α - Ωc M
IΩΓ,Β - Ωa M
XΨΓ È rk È ΨΑ \ XΨΑ È ri È ΨΒ \ XΨΒ È rj È ΨΦ \ 8r1 ® x, r2 ® y, r3 ® z<
+ .
Try the function out. Use numerical indices (1,2,3) for input; the output automatically contains the corresponding Cartesian variables (x, y, z) :
Sa,b,c 1,1,2
XΨΑ È x È ΨΒ \ XΨΒ È x È ΨΦ \ XΨΓ È y È ΨΑ \ H-Ωc + ΩΓ,Α L H-Ωa + ΩΓ,Β L
+
XΨΑ È x È ΨΒ \ XΨΒ È y È ΨΦ \ XΨΓ È x È ΨΑ \ H-Ωa + ΩΓ,Α L H-Ωb + ΩΓ,Β L
XΨΑ È y È ΨΒ \ XΨΒ È x È ΨΦ \ XΨΓ È x È ΨΑ \
+
H-Ωb + ΩΓ,Α L H-Ωc + ΩΓ,Β L
It works as desired. We verify that index permutation is a symmetry of this formula, but only if the Cartesian indices i,j,k and the photon indices a,b,c are permuted together: b,c,a c,a,b Sa,b,c i,j,k == Sj,k,i == Sk,i,j
True
46.1.2 Proof that the matrix element is a tensor Closed; please read from CD
46.2. The projection Because of the similarity to 45.2.1 we give only a sketch. A concrete example of the object to be projected is
Sa,b,c 1,2,3
XΨΑ È x È ΨΒ \ XΨΒ È y È ΨΦ \ XΨΓ È z È ΨΑ \ H-Ωc + ΩΓ,Α L H-Ωa + ΩΓ,Β L
+ +
603
Symmetry Theory XΨΑ È y È ΨΒ \ XΨΒ È z È ΨΦ \ XΨΓ È x È ΨΑ \ H-Ωa + ΩΓ,Α L H-Ωb + ΩΓ,Β L
XΨΑ È z È ΨΒ \ XΨΒ È x È ΨΦ \ XΨΓ È y È ΨΑ \
+
H-Ωb + ΩΓ,Α L H-Ωc + ΩΓ,Β L
Our operator ProjectET works on any expression that has x, y, and z in it, so it will work on this one. We project and look at just a fragment of the output: a,b,c
test = ProjectETBS1,2,3 , "C3"F; ByteCount@testD 73 416
It' s huge. Look at just a small fragment of it: testP2, 2, 81, 8
XΨΑ È y È ΨΒ \ XΨΒ È z È ΨΦ \ XΨΓ È x È ΨΑ \ 3 HΩa Ωb - Ωb ΩΓ,Α - Ωa ΩΓ,Β + ΩΓ,Α ΩΓ,Β L XΨΑ È z È ΨΒ \ [ΨΒ
- x2 -
3 y 2
-
ΨΦ _ [ΨΓ
3 x 2
-
6 HΩb Ωc - Ωc ΩΓ,Α - Ωb ΩΓ,Β + ΩΓ,Α ΩΓ,Β L
y 2
ΨΑ _
As expected, many of the Cartesian variables have been replaced by linear combinations of Cartesian variables, and the resulting expressions need to be expanded. We omit the step-by step expansion that we showed in the twophoton chapter. In the end, you have some linear combination of some or all of a,b,c
a,b,c
the 27 simple S elements, S1,1,1 to S3,3,3 .
46.3 Self-purifying tensor elements Closed; please read from CD
46.4. Operators for tensor projection 46.4.1. Projection of the whole tensor Now with this linearity definition active, observe how the projection of T[x,x,x] under group C3 h automatically simplifies itself :
604
Projection operators
ProjectET@T@x, y, zD, "C3"D; % Column :A,
1 2
:Ea, 1 4
T@x, y, zD -
ä T@x, x, zD +
:Eb,
1 4
- 14 ä T@x, x, zD +
1 2
T@y, x, zD>
T@x, y, zD +
1 4
1 4
T@x, y, zD +
T@y, x, zD -
1 4
1 4
T@y, x, zD +
ä T@y, y, zD>
1 4
ä T@y, y, zD>
a,b,c
When we did this with the authentic S1,2,3 we got an expression 73,000 bytes long. The surrogate is doing its job. This means we can easily do the whole tensor of T-functions at once. In the preliminaries we set up a tensor Tijk of the twenty-seven simple T functions: Tijk
888T@x, 8T@x, 8T@x, 88T@y, 8T@y, 8T@y, 88T@z, 8T@z, 8T@z,
x, y, z, x, y, z, x, y, z,
xD, xD, xD, xD, xD, xD, xD, xD, xD,
T@x, T@x, T@x, T@y, T@y, T@y, T@z, T@z, T@z,
x, y, z, x, y, z, x, y, z,
yD, yD, yD, yD, yD, yD, yD, yD, yD,
T@x, T@x, T@x, T@y, T@y, T@y, T@z, T@z, T@z,
x, y, z, x, y, z, x, y, z,
zD<, zD<, zD<<, zD<, zD<, zD<<, zD<, zD<, zD<<<
so we just project the whole Tijk tensor. We make it a little slicker by defining a specialized projection operator called TraceProjectTijk, consisting of a perfectly ordinary projection, plus a filter that gets rid of any all-zero projections.
46.4.2. The simplest example As our first demo we do a very simple case, group C2 , with only two species. It has only one transform, rotation about z by half a turn. But it gives a non-trivial trace projection: trPrjC2 = TraceProjectTijk@"C2"D
8C2, 88A, 8880, 0, T@x, x, zD<, 80, 0, T@x, y, zD<, 8T@x, z, xD, T@x, z, yD, 0<<, 880, 0, T@y, x, zD<, 80, 0, T@y, y, zD<, 8T@y, z, xD, T@y, z, yD, 0<<, 88T@z, x, xD, T@z, x, yD, 0<, , <<<,
605
Symmetry Theory 8T@z, y, xD, T@z, y, yD, 0<, 80, 0, T@z, z, zD<<<<, 8B, 888T@x, x, xD, T@x, x, yD, 0<, 8T@x, y, xD, T@x, y, yD, 0<, 80, 0, T@x, z, zD<<, 88T@y, x, xD, T@y, x, yD, 0<, 8T@y, y, xD, T@y, y, yD, 0<, 80, 0, T@y, z, zD<<, 880, 0, T@z, x, zD<, 80, 0, T@z, y, zD<, 8T@z, z, xD, T@z, z, yD, 0<<<<<<
This is easier to read with a little display help (explained below) : C2display = MakeTijkDisplay@8trPrjC2<, 8FontFamily ® "Arial", 8
8A, B<
0
0
T@x, z, xD T@x, z, yD 0
0
0
T@x, x, zD T@x, y, zD
0
T@y, z, xD T@y, z, yD 0
0
T@z, x, xD T@z, x, yD T@z, y, xD T@z, y, yD 0
0
T@x, x, xD T@x, x, yD T@x, y, xD T@x, y, yD 0
0
T@y, x, xD T@y, x, yD T@y, y, xD T@y, y, yD 0
0
0
0
T@z, z, xD T@z, z, yD 0
0
0
T@y, x, zD T@y, y, zD 0 0
T@z, z, zD 0
0
T@x, z, zD 0
0
T@y, z, zD 0
T@z, x, zD T@z, y, zD 0
Null
The species A projection is the top box; species B, the bottom. Now you can see at a glance that the two projections add up to the original. In a two-fold rotation about z both x and y change sign; z remains unchanged. Read carefully and 606 you will see that those elements that are unchanged by the rotation are in species A; those that change sign are in species B. This is the basic idea of symmetry projection.
Projection operators
The species A projection is the top box; species B, the bottom. Now you can see at a glance that the two projections add up to the original. In a two-fold rotation about z both x and y change sign; z remains unchanged. Read carefully and you will see that those elements that are unchanged by the rotation are in species A; those that change sign are in species B. This is the basic idea of symmetry projection.
46.4.3. Trace projection, TraceProjectTijk Do this again with C3 v , which has a true 2D species. As always, the 2D species name is E, or something anchored on an E: BoxedCharacterTable@"C3v"D C3v
1
2
3
¬ Class populations
A1
E 1
C3 1
Σv 1
A2
1
1
-1
Basis functions 8H z L, H x2 + y2 L, H z2 L< 8H Iz L<
E
2 -1
0 :K
x O, y
1 2
Ix2 - y2 M xy
,K
xz Ix O, K O> yz Iy
First do a trace projection. The display is so long that we suppress it, but interactive readers may remove the semicolon and see the whole thing. tracePrjTijkC3v = TraceProjectTijk@"C3v"D; % ByteCount 17 232
From its size alone, and more especially if you look at it, you will appreciate the utter impossibility of grasping its structure without symbolization. So, of course, an appropriate symbolizer has been written It works just like the one in the two-photon chapter: entryC3v = SymbolizeProjectionTijk@tracePrjTijkC3vD 8C3v, 88A1, 888A, 0, B<, 80, -A, 0<, 8C, 0, 0<<, 880, -A, 0<, 8-A, 0, B<, 80, C, 0<<, 88D, 0, 0<, 80, D, 0<, 80, 0, F<<<<, 8A2, 8880, G, 0<, 8G, 0, H<, 80, J, 0<<, 88G, 0, -H<, 80, -G, 0<, 8-J, 0, 0<<, 880, K, 0<, 8-K, 0, 0<, 80, 0, 0<<<<, 8E, 888L, M, N<, 8P, Q, R<, 8S, U, V<<, 88W, X, R<, 8Y, Z, -N<, 8U, -S, ZA<<, 88ZB, ZC, ZD<, 8ZC, -ZB, ZE<, 8ZF, ZG, 0<<<<<<
We see only Latin capitals, so the trace projections have no explicit ä in them. We also have a 2D display for this kind of output. We show it off without discussing its innards: 607
Symmetry Theory
We also have a 2D display for this kind of output. We show it off without discussing its innards: MakeTijkDisplay@8entryC3v<, 8FontFamily ® "Arial", 8
C3v A
0
B
0
-A
0
D
0
0
0
-A
0
-A
0
B
0
D
0
C
0
0
0
C
0
0
0
F
G
0
-H
0
K
0
H
0
-G
0
-K
0
0
0
-J
0
0
0
0
0
0
G
0
G
0
0
J
L
M
N
W
X
R
ZB
ZC
ZD
P
Q
R
Y
Z
-N
ZC
-ZB
ZE
S
U
V
U
-S
ZA
ZF
ZG
0
Each 27-element tensor is enclosed in its own box, with the group name and the species names in an introductory line. If you want to know what these symbols stand for, you may call up a quantity named Symbolizations that was created while SymbolizeTijk was operating. Here it is in Short view: Symbolizations Short@ð, 8D & ::
1
T@x, x, xD -
4
A>, :
:
1
1
T@x, y, yD -
4 1
T@x, z, xD +
T@y, x, yD -
4
T@x, x, zD +
2
1
1
1
T@y, y, xD ®
4
T@y, y, zD ® B>,
2 1
T@y, z, yD ® C>, 23,
8T@z, y, zD ® ZE<, 8T@z, z, xD ® ZF<, 8T@z, z, yD ® ZG<> 2
2
Symbolizations is overwritten each time SymbolizeTijk runs, so it must be preserved immediately if you want to use it.
608
Projection operators
46.4.4. Detailed projection, DetailedProjectTijk When a group has an E species, the trace projection gives only the sum of the two detailed projections. To see them individually, you must do a detailed projection. The operator for this has a lot to do. First it has to make a full representation of the group, and the basis it uses for this is an important point. It always uses the first basis listed in the character table, which in the case of species E¢ of D3 h is {x,y}. But complications are minimized if it transforms basis {a,b} into {a + ä b,a - ä b}. So in this case it uses {x + ä y,x - ä y}. The rep is quickly found by MakeRepPoly, and it is used by ProjectED[expr,rep,component,"C3"] with components 1 and 2. It always appends an a and a b to the E-type species name to form the names of the detailed projections that are found. Watch it work: detailedPrjC3v = DetailedProjectTijk@tracePrjTijkC3vD; The display is too long; we suppress it. There is an Ea projection from component 1, and an Eb from 2. We want to look at the Ea projection by itself. So where is the Ea label? We find it by systematic winnowing: detailedPrjC3vP2, 3, 1, 1T Ea
So the three-index tensor itself should be part P2,3,1,2T. EaRaw = detailedPrjC3vP2, 3, 1, 2T; % Dimensions 83, 3, 3<
Correct; it is a three-index Cartesian tensor. So how big is it? ByteCount@EaRawD 18 856
Interactive readers can look at it if they want to, but no human can see patterns in that much output. We have gone through all this just to show that symbolization is now quite essential.
609
Symmetry Theory
46.4.5. Symbolization by SymbolizeProjectionTijk Closed; please read from CD
46.4.6. The combined operator MakeRawEntryTijk Closed; please read from CD
46.4.7. The operator TPTdisplay The output of SymbolizeProjectionTijk is still a little hard to read for non-Mathematica people. So we have written an operator TPTdisplay that cleans them up like a typesetter might. Its input is a list of raw table entries and a style specification. Only fanatics will open the preliminaries to see how it works. Here is an example: C3display = MakeTijkDisplay@ 8entryC3<, 8FontFamily ® "Arial", 8
8A, Ea, Eb<
B
-A
-D
H
J
D
-A
-B
C
-J
H
0
0
-G
F
0
0
0
K
A
B
C
B
-A
F
G
0
Α
Β
Γ
-ä ¶
ä∆
äΓ
Θ
äΘ
Ι
∆
¶
äΓ
äΒ
-ä Α
-Γ
äΘ
-Θ
-ä Ι
Ζ
äΖ
Η
äΖ
-Ζ
-ä Η
Κ
-ä Κ
0
Α*
Β*
*
*
∆
*
Ζ
Γ*
-ä Γ
¶
-ä Ζ
*
*
Η
*
ä ¶* -ä ∆* -ä Γ* -ä Β* ä Α* - Γ* -ä Ζ * - Ζ * ä Η*
Θ*
-ä Θ Κ*
*
-ä Θ* Ι* - Θ* ä Ι* ä Κ* 0
Column@NullD
The name of the group is shown in boldface, followed by a list of species that have nonzero tensor projections; then on the next line are the respective patterns, in grids that help the eye. Degenerate patterns are bracketed together. All-zero patterns are omitted. The patterns of several groups are identical. So the display generator also 610 searches the raw entries input list for cases that have identical patterns, and groups them together, printing the patterns only once.
Projection operators
The patterns of several groups are identical. So the display generator also searches the raw entries input list for cases that have identical patterns, and groups them together, printing the patterns only once.
46.5 Three-photon tensor projection table 46.5.1. Make all non-zero table entries (no styling) We could do all our tabulated groups in one fell swoop, but group I takes so long that we separate it out. GroupCatalogNoI = Complement@GroupCatalog, 8"I"
8C1, C2, C2h, C2v, C3, C3h, C3v, C4, C4h, C4v, C5, C6, C6h, C6v, Ch, Ci, D2, D2d, D2h, D3, D3d, D3h, D4, D4d, D4h, D5, D5d, D5h, D6, D6d, D6h, O, Oh, S4, S6, S8, T, Td, Th<
Apply MakeRawEntryTijk to this long list of group names. In the beginning you will see a lot of flashing. It is trying to display the name of the group it is working on, but the small, simple groups flash by too quickly to read. Only the larger groups take a perceptible time; in particular, groups with five-fold axes are quite slow (be patient; they will finish). All this is done in infinite precision. allRaw = MakeRawEntryTijk@GroupCatalogNoID; Look at just one of the results : prjD4h = allRawP25T
8D4h, 88A1u, 8880, 0, 0<, 80, 0, 0<, 80, 0, 0<<, 880, 0, 0<, 80, 0, 0<, 80, 0, 0<<, 880, 0, 0<, 80, 0, 0<, 80, 0, 0<<<<, 8A2u, 8880, 0, A<, 80, 0, 0<, 8B, 0, 0<<, 880, 0, 0<, 80, 0, A<, 80, B, 0<<, 88C, 0, 0<, 80, C, 0<, 80, 0, D<<<<, 8B1u, 8880, 0, 0<, 80, 0, F<, 80, G, 0<<, 880, 0, F<, 80, 0, 0<, 8G, 0, 0<<, 880, H, 0<, 8H, 0, 0<, 80, 0, 0<<<<, 8B2u, 8880, 0, 0<, 80, 0, 0<, 80, 0, 0<<, 880, 0, 0<, 80, 0, 0<, 80, 0, 0<<, 880, 0, 0<, 80, 0, 0<, 80, 0, 0<<<<, 88Eua, 888Α, Β, 0<, 8Γ, ∆, 0<, 80, 0, ¶<<, 88∆* , Γ* , 0<, 8Β* , Α* , 0<, 80, 0, ¶* <<, <<,
611
Symmetry Theory 880, 0, Ζ<, 80, 0, Ζ* <, 8Η, Η* , 0<<<<, 8Eub, 888Α* , Β* , 0<, 8Γ* , ∆* , 0<, 80, 0, ¶* <<, 88∆, Γ, 0<, 8Β, Α, 0<, 80, 0, ¶<<, 880, 0, Ζ* <, 80, 0, Ζ<, 8Η* , Η, 0<<<<<<<
This is the information that will be tabulated for D4 h , but in a more readable, typeset format, provided by the operator MakeTijkDisplay. MakeTijkDisplay@8prjD4h<, 8FontFamily ® "Arial", 8
D4h
8A1u, A2u, B1u, B2u, 8Eua, Eub<<
0
0
0
0
0
0
0
0
0
0
0
A
0
0
0
C
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
A
0
C
0
0
0
0
0
0
0
0
0
0
B
0
0
0
B
0
0
0
D
0
:
0
0
0
0
0
G
Α Γ
0
F
0
H
0
0
0
0
0
0
0
0
0
0
F
0
0
0
H
0
0
0
0
0
0
0
0
0
0
0
0
G
0
0
0
0
0
0
0
0
0
0
0
0
0
0
Β ∆
0
612
0
0
∆*
Γ*
0
0
0
Ζ
0
*
*
0
0
0
Ζ*
0
*
Η
*
0
0
0
Ζ*
Β
¶
0
Α*
Β*
*
Γ
*
∆
0
0
Α
0
¶
Η
∆
Γ
0
0
Β
Α
0
0
0
Ζ
¶*
0
0
¶
Η*
Η
0
0
,
>
Three-photon projection table
46.5.2. Table of three-photon tensor patterns All that is left is the display operator MakeTijkDisplay. This where the axial permutation rules are applied, so if you see an all-zero tensor, axial symmetry caused it. More normal all zero projections have been filtered out. MakeTijkDisplay@allRaw, 8FontFamily ® "Arial", 8
C1
8Au<
Ci
A
B
C
L
M
N
W
X
Y
D
F
G
P
Q
R
Z
ZA
ZB
H
J
K
S
U
V
ZC
ZD
ZE
0
0
F
K
L
8A, B<
C2 C2h
8Au, Bu<
0
0
A
0
0
B
0
0
G
M
N
0
C
D
0
H
J
0
0
0
P
Q
R
0
W
X
S 0
0
U
0
Y
Z
0
0
V
0
0
ZA
0
0
0
ZB
0
0
ZC
ZD
ZE
0
613
Symmetry Theory 8A1 , A2, B1, B2<
C2v
C3 S6
0
0
A
0
0
0
0
B
0
0
0
F
0
0
0
0
0
C
0
0
D
0
0
G
0
0
0
0
H
0
K
Q
0
0
0
U
0
0
0
W
0
R
0
V
0
0
0
0
0
0
0
S
0
0
0
X
0
0
0
Y
0
ZA
0
0
0
0
0
Z
0
0
0
ZB
0
0
0
ZD
0
0
0
0
0
ZC
0
ZE
0
0
0
0
0
0
L
0
N
0
J
0
0
0
P
0
0
0
M
0
0
0
0
0
8A, Ea, Eb<
8Au, Eua, Eub< A
B
C
B
-A
-D
H
J
B
-A
D
-A
-B
C
-J
H
0
F
G
0
-G
F
0
0
0
K
Α
Β
Γ
-ä ¶
ä∆
äΓ
Θ
äΘ
Ι
∆
¶
äΓ
äΒ
-ä Α
-Γ
äΘ
-Θ
-ä Ι
Ζ
äΖ
Η
äΖ
-Ζ
-ä Η
Κ
-ä Κ
0
Α*
Β*
∆*
¶*
*
Ζ
614
0
-ä Ζ
Γ*
-ä Γ* *
*
Η
ä ¶* -ä ∆* -ä Γ* -ä Β* ä Α* - Γ* * * -ä Ζ -Ζ ä Η*
Θ*
-ä Θ* Κ*
-ä Θ* Ι* - Θ* ä Ι* ä Κ* 0
Three-photon projection table ¢¢ 9A¢ , E¢a , E¢b , A¢¢ , E¢¢ a , Eb =
C3h
-A
0
0
0
0
-A -B
0
0
0
0
0
0
0
0
A
B
0
B
-A
0
B
0
0
0
0
0
Α
Β
0
-ä ∆
äΓ
0
0
0
Ζ
Γ
∆
0
äΒ
-ä Α
0
0
0
-ä Ζ
0
0
¶
0
0
-ä ¶
Η
-ä Η
0
0
0
0
0
0
0
ä ¶*
*
Α*
Β*
0
*
*
∆
0
0
*
Γ
0
ä ∆* -ä Γ* -ä Β* ä Α*
¶
0
0
Η
0
0
C
0
0
-D
H
J
0
0
0
D
0
0
C
-J
H
0
F
G
0
-G
F
0
0
0
K
0
0
Θ
0
0
äΘ
Κ
äΚ
0
0
0
äΘ
0
0
-Θ
äΚ
-Κ
0
Ι
äΙ
0
äΙ
-Ι
0
0
0
0
0
0
Θ*
0
0
-ä Θ
Ι*
-ä Ι*
0
0 *
0
0 0
-ä Ι* - Ι*
Ζ*
ä Ζ* *
äΗ
0
Κ*
-ä Θ* - Θ*
-ä Κ
0
0
*
-ä Κ* - Κ*
0
0
0
0
615
Symmetry Theory
C3v
:
8A1, A2, 8Ea, Eb<<
A
0
B
0
-A
0
D
0
0
-A
0
-A
0
B
0
D
0
C
0
0
0
C
0
0
0
F
0
G
0
G
0
-H
0
K
0
G
0
H
0
-G
0
-K
0
0
0
J
0
-J
0
0
0
0
0
Α
Β
Γ
-ä ¶
ä∆
äΓ
Θ
äΘ
Ι
∆
¶
äΓ
äΒ
-ä Α
-Γ
äΘ
-Θ
-ä Ι
Ζ
äΖ
Η
äΖ
-Ζ
-ä Η
Κ
-ä Κ
0
Α*
Β*
∆*
¶*
*
Ζ
616
0
-ä Ζ
Γ*
-ä Γ* *
*
Η
ä ¶* -ä ∆* -ä Γ* -ä Β* ä Α* - Γ* * * -ä Ζ -Ζ ä Η*
,
Θ*
-ä Θ* Κ*
-ä Θ* Ι* - Θ* ä Ι* ä Κ* 0
>
Three-photon projection table 8A, B, Ea, Eb<
C4 C4h
8Au, Bu, Eua, Eub<
0
0
A
0
0
B
C
D
0
0
-B
F
G
0
0
A
-G
F
0
-D
C
0
0
0
H
0
0
0
0
J
0
0
K
N
P
0
0
0
K
0
0
-J
P
-N
0
L
M
0
M
-L
0
0
0
0
Α
Β
0
ä∆
-ä Γ
0
0
0
Ζ
Γ
∆
0
-ä Β
äΑ
0
0
0
äΖ
0
0
¶
0
0
ä¶
Η
äΗ
0
Α*
Β*
0
Γ*
∆*
0
0
*
0
¶
-ä ∆* ä Γ* ä Β* -ä Α* 0
0
0 0 *
-ä ¶
0
0
0
0
*
Η
Ζ*
-ä Ζ * *
-ä Η
0
617
Symmetry Theory
C4v
:
618
8A1, A2, B1, B2, 8Ea, Eb<<
0
0
A
0
0
0
C
0
0
0
0
B
0
0
0
0
0
0
0
0
0
0
0
0
0
0
A
0
0
B
0
0
C
0
0
0
0
0
0
0
0
0
0
0
D
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
F
0
H
0
0
0
0
0
0
0
0
0
0
0
0
F
0
0
0
H
0
0
0
0
0
0
0
0
0
0
0
0
G
0
G
0
0
0
0
0
Α
Β
0
∆*
Γ*
*
0
0
0
Ζ
Γ
∆
0
Β
Α*
0
0
0
Ζ*
0
0
¶
0
0
¶*
Η
Η*
0
0
0
Ζ*
Α*
Β*
*
Γ
*
∆
0
0
∆
Γ
0
0
Β
Α
0
0
0
Ζ
¶*
0
0
¶
Η*
Η
0
0
,
>
Three-photon projection table
C5
8A, E1a, E1b, E2a, E2b< 0
0
A
0
0
-B
F
G
0
0
B
0
0
A
-G
F
0
C
D
0
-D
C
0
0
0
H
0
Α
Β
0
ä∆
-ä Γ
0
0
0
Ζ
Γ
∆
0
-ä Β
äΑ
0
0
0
äΖ
0
0
¶
0
0
ä¶
Η
äΗ
0
-ä ∆* ä Γ* ä Β* -ä Α*
Α*
Β*
0
Γ*
∆*
0
0
*
0
¶
0
0 0
0
0
0
*
*
-ä ¶
0
0 Η
Θ
-ä Θ
Ι
-ä Θ
-Θ
äΙ
Λ
äΛ
0
-ä Θ
-Θ
äΙ
-Θ
äΘ
-Ι
äΛ
-Λ
0
Κ
äΚ
0
äΚ
-Κ
0
0
0
0
Θ*
ä Θ* Ι* - Θ* -ä Ι* -ä Κ* 0
äΘ Κ*
*
ä Θ* - Θ* -ä Ι* - Θ* -ä Θ* - Ι* -ä Κ* - Κ* 0
Ζ*
-ä Ζ * *
-ä Η
0
Λ*
0
-ä Λ
-ä Λ* - Λ*
0
0
0
*
0
619
Symmetry Theory 8A, B, E1a, E1b, E2a, E2b<
C6
8Au, Bu, E1ua, E1ub, E2ua, E2ub<
C6h 0
0
A
0
0
B
C
D
0
620
-B
F
G
0
0
A
-G
F
0
-D
C
0
0
0
H
0
J
K
0
K
-J
0
0
0
0
K
-J
0
-J
-K
0
0
0
0
0
0
0
0
0
0
0
0
0
Α
Β
0
ä∆
-ä Γ
0
0
0
Ζ
Γ
∆
0
-ä Β
äΑ
0
0
0
äΖ
0
0
¶
0
0
ä¶
Η
äΗ
0
Α*
Β*
0
Γ*
∆*
0
0
*
0
C6v
0
0
-ä ∆* ä Γ* ä Β* -ä Α*
¶
0
0 0 *
-ä ¶
0
0
0
Θ
0
0
äΘ
Κ
äΚ
0
0
0
äΘ
0
0
-Θ
äΚ
-Κ
0
Ι
äΙ
0
äΙ
-Ι
0
0
0
0
0
0
Θ*
0
0
-ä Θ*
Ι*
-ä Ι*
0
0
0
0
0
-ä Ι* - Ι*
0
A
0
0
0
C
0
0
0
0
0
0
A
0
C
0 0
B
0
0
0
B
0
0
0
D
0
0
0
*
Η
Ζ*
-ä Ζ * *
-ä Η
Κ*
-ä Θ* - Θ*
-ä Κ
0
0
8A1, A2, B1, B2, 8E1a, E1b<, 8E2a, E2b<<
0
0
*
0
-ä Κ* - Κ*
0
0
0
0
Three-photon projection table
:
0
0
0
0
0
-F
0
H
0
0
0
F
0
0
0
-H
0
0
0
G
0
-G
0
0
0
0
0
0
J
0
J
0
0
0
0
0
J
0
0
0
-J
0
0
0
0
0
0
0
0
0
0
0
0
0
K
0
0
0
-K
0
0
0
0
0
-K
0
-K
0
0
0
0
0
0
0
0
0
0
0
0
0
0
Α
Β
0
-ä ∆
äΓ
0
0
0
Ζ
Γ
∆
0
äΒ
-ä Α
0
0
0
-ä Ζ
0
0
¶
0
0
-ä ¶
Η
-ä Η
0
0
0
0
Ζ*
0
0
0
ä Ζ*
Β*
0
*
*
∆
0
0
*
Γ
0
:
ä ∆* -ä Γ* -ä Β* ä Α*
Α*
¶
0
*
*
ä¶
0
Η
,
*
äΗ
0
0
Θ
0
0
-ä Θ
Κ
-ä Κ
0
0
0
-ä Θ
0
0
-Θ
-ä Κ
-Κ
0
Ι
-ä Ι
0
-ä Ι
-Ι
0
0
0
0
0
0
Θ*
0
0
äΘ
Ι*
ä Ι*
0
*
0
0
0
0
ä Ι* - Ι*
ä Θ* - Θ* 0
Κ*
>
0
,
0
ä Κ*
ä Κ* - Κ*
0
0
0
0
>
621
Symmetry Theory 8A, B<
Ch
A
B
C
D
0
0
G
H
0
0
J
K
0
F
0
0
L
0
0
M
0
0
N
P
Q
0
0
0
R
0
0
W
ZA
ZB
0
0
S
0
0
X
ZC
ZD
0 0
U
V
0
Y
Z
0
0
0
ZE
8A, B1, B2, B3<
D2 D2h
8Au, B1u, B2u, B3u<
0
622
0
0
0
0
0
C
0
F
0
0
0
H
0
0
0
M
0
0
0
0
B
A
0
0
0
G
0
0
0
0
0
0
0
K
0
N
0
0
D
0
0
0
0
0
J
0
0
0
L
0
0
0
P
0
Q
0
S
0
0
0
0
0
R
0
0
0
U
0
0
0
W
0
0
0
0
0
V
0
X
0
Y
0
0
0
ZB
0
0
0
ZD
0
Z
0
ZC
0
0
0
0
0
0
0
ZA
0
0
0
ZE
0
0
0
Three-photon projection table
D2d
8A1 , A2 , B1 , B2 , 8Ea, Eb<<
0
:
0
0
0
0
A
0
C
0
0
0
0
0
0
0
0
0
0
0
0
0
B
A
0
0
0
C
0
0
0
0
0
0
0
0
0
0
0
0
B
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
D
0
0
0
G
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
D
0
G
0
0
0
0
0
0
0
0
0
0
F
0
0
0
F
0
0
0
H
Α
Β
0
∆*
Γ*
*
0
0
0
Ζ
Γ
∆
0
Β
Α*
0
0
0
Ζ*
0
0
¶
0
0
¶*
Η
Η*
0
0
0
Ζ*
Α*
Β*
*
Γ
*
∆
0
0
∆
Γ
0
0
Β
Α
0
0
0
Ζ
¶*
0
0
¶
Η*
Η
0
0
0
,
>
623
Symmetry Theory 8A1, A2, 8Ea, Eb<<
D3 D3d
8A1u, A2u, 8Eua, Eub<< 0
0
0
-A
B
-A
0
0
C
0
-C
0
D
0
0
-D
0
0
0
0
0
0
F
G
F
0
0
J
0
0
0
0
-F
G
0
J
0
H
0
0
0
H
0
0
0
K
0
Α
Β
Γ
-ä ¶
ä∆
äΓ
Θ
äΘ
Ι
∆
¶
äΓ
äΒ
-ä Α
-Γ
äΘ
-Θ
-ä Ι
Ζ
äΖ
Η
äΖ
-Ζ
-ä Η
Κ
-ä Κ
0
Α*
Β*
∆*
¶*
-ä Ζ
Ζ
624
0
0
*
D3h
0
F
:
:
-A -B
A
Γ*
Θ*
ä ¶* -ä ∆* -ä Γ* -ä Β* ä Α* - Γ* * * -ä Ζ -Ζ ä Η*
-ä Γ* *
*
,
Η
-ä Θ* Κ*
-ä Θ* Ι* - Θ* ä Ι* ä Κ* 0
¢¢ ¢¢ ¢¢ 9A¢1 , A¢2 , 8E¢ a, E¢ b<, A¢¢ 1 , A2 , 8E a, E b<=
A
0
0
0
-A
0
0
0
0
0
-A
0
-A
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
B
0
B
0
0
0
0
0
B
0
0
0
-B
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
Α
Β
0
-ä ∆
äΓ
Γ
∆
0
äΒ
-ä Α
0
0
0
¶
0
0
-ä ¶
0
Ζ
0
0
-ä Ζ
Η
-ä Η
0
,
>
>
Three-photon projection table
Α*
Β*
0
*
*
∆
0
0
*
Γ
0
0
:
0
0
0
Ζ*
0
0
0
ä Ζ*
ä ¶*
*
ä Η*
0
ä ∆* -ä Γ* -ä Β* ä Α*
¶
0
0
0
0
-C
0
F
0
C
0
0
0
-F
0
0
0
-D
0
0
0
0
0
0
G
0
0
0
J
0
0
0
0
0
G
0
J
0
0
0
0
H
0
0
0
K
0
0
0
0
0
D
0 0 H
Η
0
0
0
Θ
0
0
äΘ
Κ
äΚ
0
0
0
äΘ
0
0
-Θ
äΚ
-Κ
0
Ι
äΙ
0
äΙ
-Ι
0
0
0
0
0 0 *
Ι
Θ*
0
-ä Θ
0 *
-ä Ι
0
*
0
0
0
0 *
-ä Ι
>
*
-Ι
-ä Θ* - Θ* 0
,
Κ*
0
-ä Κ*
-ä Κ* - Κ*
0
0
0
0
>
625
Symmetry Theory 8A1, A2, B1, B2, 8Ea, Eb<<
D4
0
0
0
0
0
-A
0
C
0
0
0
A
0
0
0
-C
0
0
0
B
0
-B
0
0
0
0
0
0
0
D
0
0
0
G
0
0
0
0
0
0
0
J
0
L
0
0
0
0
0
0
D
0
G
0
0
0
J
0
0
0
L
0
0
F
0
0
0
F
0
0
0
H
0
K
0
K
0
0
0
0
0
0
0
M
0
0
0
P
0
0
0
0
0
0
0
-M
0
-P
0
N
0
0
0
-N
0
0
0
0
0
0
0
Ζ
:
Α
Β
0
-ä ∆
äΓ
Γ
∆
0
äΒ
-ä Α
0
0
0
-ä Ζ
0
0
¶
0
0
-ä ¶
Η
-ä Η
0
0
0
0
Ζ*
0
0
0
ä Ζ*
ä ¶*
*
ä Η*
0
Α*
Β*
0
*
*
∆
0
0
*
Γ
0
"" D4d
626
ä ∆* -ä Γ* -ä Β* ä Α*
¶
0
0
Η
8B1, B2, 8E1a, E1b<, 8E2a, E2b<, 8E3a, E3b<<
0
0
0
0
0
-A
0
C
0
0
0
A
0
0
0
-C
0
0
0
B
0
-B
0
0
0
0
0
0
0
D
0
0
0
G
0
0
0
0
0
0
D
0
G
0 0
F
0
0
0
F
0
0
0
H
,
>
Three-photon projection table
:
Α
Β
0
-ä ∆
äΓ
0
0
0
Ζ
Γ
∆
0
äΒ
-ä Α
0
0
0
-ä Ζ
0
0
¶
0
0
-ä ¶
Η
-ä Η
0
0
0
0
0
0
Α*
Β*
0
*
*
∆
0
0
*
Γ
0
:
¶
0
0
*
*
ä¶
0
Η
0
0
Θ
0
0
äΘ
Κ
äΚ
0
0
0
äΘ
0
0
-Θ
äΚ
-Κ
0
Ι
äΙ
0
äΙ
-Ι
0
0
0
0
0
:
ä ∆* -ä Γ* -ä Β* ä Α*
Θ*
0
0
0
0
-ä Θ
Ι*
-ä Ι*
0
*
0
0 0
-ä Ι* - Ι*
,
Ζ*
ä Ζ* *
äΗ
,
Κ*
-ä Θ* - Θ*
-ä Κ
0
0
Λ
äΛ
0
äΛ
-Λ
0
0
0
0
äΛ
-Λ
0
-Λ
-ä Λ
0
0
0
0
0
0
0
0
0
0
0
0
0
-ä Λ* - Λ* - Λ* ä Λ*
0
0
0
0
0
0
0
0
0
0
0
0
Λ*
0
-ä Λ
-ä Λ* - Λ*
0
0
0
*
0
0
0
>
0
*
-ä Κ* - Κ*
0
0
0
0
>
,
>
627
Symmetry Theory
D4h
:
628
8A1u, A2u, B1u, B2u, 8Eua, Eub<<
0
0
0
0
0
0
0
0
0
0
0
A
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
C
0
0
0
0
0
0
B
0
0
0
0
0
A
0
C
0
0
B
0
0
0
D
0
0
0
0
0
F
0
H
0
0
0
0
0
0
0
0
0
0
0
0
F
0
0
0
H
0
0
0
0
0
0
0
0
0
0
0
0
G
0
G
0
0
0
0
0
0
0
0
0
0
0
0
0
0
Α
Β
0
∆*
Γ*
*
0
0
0
Ζ
Γ
∆
0
Β
Α*
0
0
0
Ζ*
0
0
¶
0
0
¶*
Η
Η*
0
0
0
Ζ*
Α*
Β*
*
Γ
*
∆
0
0
∆
Γ
0
0
Β
Α
0
0
0
Ζ
¶*
0
0
¶
Η*
Η
0
0
,
>
Three-photon projection table 8A1, A2, 8E1a, E1b<, 8E2a, E2b<<
D5 D5d
9A1 u , A2 u , 9E1 u a, E1 u b=, 9E2 u a, E2 u b==
0
0
0
-A
0
C
0
A
0
0
0
-C
0
0
0
-B
0
0
0
0
0
0
0
0
0
0
B
0
0
D
0
0
0
G
0
0
0
0
0
0
D
0
G
0
F
0
0
0
F
0
0
0
H
:
Α
Β
0
-ä ∆
äΓ
0
0
0
Ζ
Γ
∆
0
äΒ
-ä Α
0
0
0
-ä Ζ
0
0
¶
0
0
-ä ¶
Η
-ä Η
0
0
0
0
0
0
Β*
0
Γ*
∆*
0
0
*
0
*
ä¶
0
äΗ
Η
äΘ
Ι
äΘ
-Θ
-ä Ι
Λ
-ä Λ
0
-ä Ι
-Θ
-ä Θ
-Ι
-ä Λ
-Λ
0
Κ
-ä Κ
0
-ä Κ
-Κ
0
0
0
0
*
Κ*
ä Ζ* *
-Θ
-ä Θ* Ι* - Θ* ä Ι* ä Κ* 0
Ζ*
*
Θ
-ä Θ
:
¶
0
,
äΘ
Θ*
D5h
ä ∆* -ä Γ* -ä Β* ä Α*
Α* 0
:
0
-ä Θ* - Θ* ä Ι* - Θ* ä Θ* - Ι* ä Κ* - Κ* 0
>
0
,
Λ*
0
äΛ
ä Λ* - Λ*
0
0
0
*
0
>
¢¢ ¢¢ ¢¢ 99E¢1 a, E¢1 b=, 9E¢2 a, E¢2 b=, A¢¢ 1 , A2 , 9E2 a, E2 b==
Α
Β
0
-ä ∆
äΓ
0
0
0
Ζ
Γ
∆
0
äΒ
-ä Α
0
0
0
-ä Ζ
0
0
¶
0
0
-ä ¶
Η
-ä Η
0
,
>
629
Symmetry Theory
Β*
0
Γ*
∆*
0
0
*
¶
0
:
0 *
ä¶
0
0
0
0
0
*
Η
ä Ζ* *
äΗ
äΘ
0
äΘ
-Θ
0
0
0
0
-Θ
0
-Θ
-ä Θ
0
0
0
0
0
0
0
0
0
0
0
0
0
-ä Θ* - Θ* - Θ* ä Θ*
0
0
0
0
0
0
0
0
0
0
0
0
*
-ä Θ* - Θ*
0
0
0
0
0
0
0
0
0
0
0
-A
0
C
0
0
0
A
0
0
0
-C
0
0
0
B
0
-B
0
0
0
0
0
0
0
D
0
0
0
G
0
0
0
0
0
0
0
D
0
G
0
F
0
0
0
F
0
0
0
H
0
0
-ä Ι
Λ
-ä Λ
0
0
Ι
0
0
-ä Ι
0
0
-Ι
-ä Λ
-Λ
0
Κ
-ä Κ
0
-ä Κ
-Κ
0
0
0
0
0
0
Ι*
0 *
0
0
äΙ
Κ*
ä Κ*
0
0
0 0
ä Κ* - Κ*
ä Ι* - Ι* 0
0
,
0
0
>
Ζ*
Θ
-ä Θ
630
0
0
äΘ
Θ*
:
ä ∆* -ä Γ* -ä Β* ä Α*
Α*
Λ*
>
,
0
äΛ
ä Λ* - Λ*
0
0
0
*
0
>
Three-photon projection table
D6
:
:
8A1, A2, B1, B2, 8E1a, E1b<, 8E2a, E2b<< 0
0
0
0
0 -A
C 0
0
0 D
0
0
0
G
0
0
0
A
0
0
0
-C
0
0
0
0
0
0
0 D
0
G
0
0
B
0
-B 0
0
0
0
0
F 0
0
0 F
0
0
H
0
J
0
0
0
-J
0
0
0
0
0
K
0
K
0
-J
0
-J
0
0
0
0
0
K
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
Α
Β 0
-ä ∆
äΓ
0
0
0
Ζ
Γ
∆
0
äΒ
-ä Α
0
0
0
-ä Ζ
0
0
¶
0
0
-ä ¶
Η
-ä Η
0
Α*
Β*
Γ*
*
∆
0
0
0
¶*
ä ∆* -ä Γ* -ä Β* ä Α*
0
0
0
Ζ*
0
0
0
ä Ζ*
Η*
ä Η*
0
0
0
Θ
0
0
-ä Θ
Κ
-ä Κ
0
0
0
-ä Θ
0
0
-Θ
-ä Κ
-Κ
0
Ι
-ä Ι
0
-ä Ι -Ι
0
0
0
0
0
0
Θ*
0
0
0
0
ä Θ*
0
0
Ι*
ä Ι*
0
ä Ι* - Ι*
0
ä ¶*
ä Θ* - Θ* 0
Κ*
0
0
0
0
-K 0
0
0
0
0
0
0
0
0
0
,
0
0
0
0
>
,
0
ä Κ*
ä Κ* - Κ*
0
0
0
0
>
631
Symmetry Theory
D6d
:
:
:
632
8B1, B2, 8E1a, E1b<, 8E3a, E3b<, 8E4a, E4b<<
0
0
0
0
0
0
0
0
0
0
0
A
0
0
0
C
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
A
0
C
0
0
0
0
0
0
0
0
0
0
B
0
0
0
B
0
0
0
D
Α
Β 0
∆*
Γ*
*
0
0
0
Ζ
Γ
∆
0
Β
Α*
0
0
0
Ζ*
0
0
¶
0
0
¶*
Η
Η*
0
0
0
0
Ζ*
Α*
Β*
Γ*
*
∆
0
Β Α 0
0
0
Ζ
0
0
¶*
0
¶
Η*
Η
0
∆
0
Γ 0
,
>
- Θ*
0
- Θ*
-Θ
0
0
0
0
-Θ
0
-Θ
Θ*
0
0
0
0
0
0
0
0
0
0
0
0
0
Θ*
-Θ
-Θ
- Θ*
0
0
0
0
Θ
0
0
0
0
0
0
0
Θ
-Θ
*
-Θ
-Θ
0
0
*
0
*
0
-Θ
0
0
0
0
,
>
0
0
Ι
0
0
-ä Ι
Λ
0
0
-ä Ι
0
0
-Ι
-ä Λ
-Λ
0
Κ
-ä Κ
0
-ä Κ
-Κ
0
0
0
0
-Λ
-ä Λ 0
0
0
-Ι
0
0 -ä Ι
0
0
-ä Ι
0
0
Ι
-ä Λ
-ä Λ 0 Λ
0
-Κ
-ä Κ
0
-ä Κ
Κ
0
0
0
0
,
>
0
Three-photon projection table 8A1u, A2u, B1u, B2u, 8E1ua, E1ub<, 8E2ua, E2ub<<
D6h
:
:
0
0
0
0
0 -A
C 0
0
0 D
0
0
0
G
0
0
0
A
0
0
0
-C
0
0
0
0
0
0
0 D
0
G
0
0
B
0
-B 0
0
0
0
0
F 0
0
0 F
0
0
H
0
0
J
0
J
0
0
0
0
0
K
J
0
0
0
-J
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0 0
Α
Β 0
-ä ∆
äΓ
0
0
0
Ζ
Γ
∆
0
äΒ
-ä Α
0
0
0
-ä Ζ
0
0
¶
0
0
-ä ¶
Η
-ä Η
0
Α*
Β*
Γ*
*
∆
0
0
0
¶*
ä ∆* -ä Γ* -ä Β* ä Α*
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
Ζ*
0
0
0
ä Ζ*
ä ¶*
Η*
ä Η*
0
0
Θ
0
0
-ä Θ
Κ
-ä Κ
0
0
0
-ä Θ
0
0
-Θ
-ä Κ
-Κ
0
Ι
-ä Ι
0
-ä Ι -Ι
0
0
0
0
0
0
Θ*
0
0
0
0
ä Θ*
0
0
Ι*
ä Ι*
0
ä Θ* - Θ* 0
Κ*
-K 0
-K
,
0
ä Ι* - Ι*
0
0
0
0
0
0
-K 0
0
0
>
,
0
ä Κ*
ä Κ* - Κ*
0
0
0
0
>
633
Symmetry Theory 8A1, A2, 8Ea, Eb<, 8T1a, T1b, T1c<, 8T2a, T2b, T2c<<
O Oh
8A1u, A2u, 8Eua, Eub<, 8T1ua, T1ub, T1uc<, 8T2ua, T2ub, T2uc<< 0
0
0
0 0 -A
0
0
A
0 0
0
0 -A 0
A 0
0
0 0
:
0
0 0
0
0 0 B
0 B 0
0 0 0
B 0 0
0 B 0
B 0 0
0
¶* 0
0
0
*
Ζ
0
0
∆* 0
0
0
0
0
0
0
*
Α
0
0
Β*
0
0
0 0
0
0
C 0
:
0 Γ*
0
0
F 0
0
0 F
0 D 0
G 0 0
0
0 0
0
0
G 0 0
0 D
0
0 0
0 0 M
0 0
0
P 0
0
0 0
0
0 0 M
0 P
0
N 0
0
0 N
0
0
0 0 R
0
0
0
0 0 0
0
0
-R
S 0 0
0 -S
U
0 0
0 W 0
0
0 -W
X
0
0
0
0
0
0
0
0
-X 0
0
0
0
0
0
0
0
0
-Z
0 0 0
0
0 -ZA
0 0 0
0 -Y
0 ¶ 0 0 0
,
0 H 0
K 0 0
0 0 0
J 0 0
0 L 0
0 0
0 0 0
0 0 K
0 H 0
,
0
0
0
∆ 0 0
0
0 -U 0 0
0
Ζ
0 Β 0
>
0
ZA 0
0 0 0
,
0 V
0 Y 0
0 0 Γ
0 0 Α
0 Q
0
Z 0 0
0 0 0
>
0 0
0 0 -V
634
A 0
0 0 B
0
:
0
-A 0 0
,
0
>
J
,
Three-photon projection table
S4
8A, B, Ea, Eb< 0
0
A
0
0
B
F
G
0
0
0
B
0
0
-A
G
-F
0
C
D
0
D
-C
0
0
0
0
0
0
H
0
0
-J
M
N
0
0
J
0
0
H
-N
M
0
K
L
0
-L
K
0
0
0
P
Α
Β
0
-ä ∆
äΓ
0
0
0
Ζ
Γ
∆
0
äΒ
-ä Α
0
0
0
-ä Ζ
0
0
¶
0
0
-ä ¶
Η
-ä Η
0
0
0
0
0
0
Α*
Β*
0
*
*
∆
0
0
*
Γ
0
¶
ä ∆* -ä Γ* -ä Β* ä Α* 0
0
0
0 *
ä¶
*
Η
Ζ*
ä Ζ* *
äΗ
0
635
Symmetry Theory
S8
8B, E1a, E1b, E2a, E2b, E3a, E3b< 0
0
A
0
0
-B
F
G
0
0
B
0
0
A
-G
F
0
C
D
0
-D
C
0
0
0
H
Λ
Α
Β
0
Ζ
Η
0
0
0
Γ
∆
0
Θ
Ι
0
0
0
Μ
0
0
¶
0
0
Κ
Ν
Ξ
0
Λ
Α*
Β*
0
Ζ*
Η*
0
0
0
*
Γ
*
∆
0
*
Θ
Ι*
0
0
0
Μ
0
0
¶
0
0
Κ
Ν
Ξ
0
0
0
Ρ
0
0
äΡ
V
äV
0
0
0
äΡ
0
0
-Ρ
äV
-V
0
Σ
äΣ
0
äΣ
-Σ
0
0
0
0
0
Ρ*
0
-ä
0
0
Σ*
-ä Σ*
0
-ä Σ* - Σ*
0
ä ∆* -ä Γ* -ä Β* ä Α*
0
0
0
-ä Μ
0
0
0
äΛ
ä¶
-ä Ξ
äΝ
0
Ρ
0 0
0
0
-ä Κ
0
V*
-ä Ρ* - Ρ*
0 *
0
-ä Ι* ä Θ* ä Η* -ä Ζ *
636
0
0
0
0
0
-ä V
-ä V* - V*
0
0
0
*
äΙ
-ä Θ
0
-ä ∆
äΓ
0
0
0
äΜ
-ä Η
äΖ
0
äΒ
-ä Α
0
0
0
-ä Λ
0
0
äΚ
0
0
-ä ¶
äΞ
-ä Ν
0
0
Three-photon projection table 8A1, Ea, Eb, 8Ta, Tb, Tc<<
T Th
8Au, Eua, Eub, 8Tua, Tub, Tuc<< 0
0
0
0
0
B
0
A
0
0
0
0
0
0
Γ
0
¶
0
0
0
A
0
0
0
B
0
0
0
0
Α
0
0
0
Ζ
0
0
0
B
0
A
0
0
0
0
0
0
Β
0
∆
0
0
0
0
0
0
:
0
Γ*
0
¶*
0
0
0
*
Ζ
0
0
0
0
0
0
0
0
0
0
0
0
*
Α
0
0
Β*
0
∆*
0
0
G
0
C
0
0
D
0
H
0
0
0
F
0
0
0
0
J
0
0
0
0
0
K
0
0
0
L
0
N
0
0
0
0
0
M
0
0
0
P
0
0
0
R
0
0
0
0
0
Q
0
S
0
0
0
U
0
0
0
Y
0
0
0
0
0
0
W
0
Z
0
V
0
0
0
X
0
0
0
ZA
0
,
,
>
637
Symmetry Theory
Td
8A1, A2, 8Ea, Eb<, 8T1a, T1b, T1c<, 8T2a, T2b, T2c<< 0 0 0 0 0 A 0 A 0
:
:
0 0 A 0 0 0 A 0 0
0 0 0 0 0 Α 0 Β 0
0 A 0 A 0 0 0 0 0
0 0 Γ 0 0 0 ∆ 0 0
0 ¶ 0 Ζ 0 0 0 0 0
0 0
,
0 Α*
0 0
0 Β*
0
∆* 0
0 0 -D 0 0 0 -F 0 0
,
0 G 0 H 0 0 0 0 0
J 0 0 0 0 0 0 0 -J
0 0 0 0 0 -H 0 -G 0
,
0 0 K 0 0 0 L 0 0
0 0 0 0 0 -K 0 -L 0
M 0 0 0 -M 0 0 0 0
S 0 0 0 U 0 0 0 U
0 V 0 W 0 0 0 0 0
0 0 V 0 0 0 W 0 0
>:
,
0 0 N 0 0 0 P 0 0
0 X 0 Y 0 0 0 0 0
0 B 0 -B 0 0 0 0 0
0 Γ* 0 0
0 0
0 D 0 F 0 0 0 0 0
0 0 0 0 C 0 0 0 -C
0 0 -B 0 0 0 B 0 0
0 0 0 0 0 B 0 -B 0
0
0 ¶* 0 Ζ* 0
0 0 0 0 0 N 0 P 0
Z 0 0 0 ZA 0 0 0 Z
0 0
0 0
>
Q 0 0 0 Q 0 0 0 R
0 0 0 0 0 Y 0 X 0
,
>
Group I is too slow to include in the automatic constructions above. However, it does succeed if you wait long enough. Its projections are
638
Three-photon projection table
I
8A, 8T1a, T1b, T1c<, 8F2a, F2b, F2c<, 8Ga, Gb, Gc, Gd<, 8Ha, Hb, Hc, Hd, He<< 0 0 0 0 0 A 0 -A 0
:
:
:
0 0 -A 0 0 0 A 0 0
0 A 0 -A 0 0 0 0 0
B 0 0 0 C 0 0 0 C
0 D 0 F 0 0 0 0 0
0 0 D 0 0 0 F 0 0
0 0 F 0 0 0 D 0 0
0 0 0 0 0 F 0 D 0
C 0 0 0 C 0 0 0 B
J 0 0 0 G 0 0 0 H
0 G 0 G 0 0 0 0 0
K 0 0 0 L 0 0 0 M
0 L 0 L 0 0 0 0 0
0 M 0 M 0 0 0 0 0
M 0 0 0 K 0 0 0 L
0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0
0 0 0 0 -R 0 0 0 R
0 0 -P 0 0 0 -Q 0 0
,
>:
0 F 0 D 0 0 0 0 0
C 0 0 0 B 0 0 0 C
0 0 0 0 0 D 0 F 0
0 0 G 0 0 0 G 0 0
0 0 0 0 0 H 0 H 0
G 0 0 0 H 0 0 0 J
H 0 0 0 J 0 0 0 G
0 0 0 0 0 G 0 G 0
0 0 H 0 0 0 H 0 0
,
0 H 0 H 0 0 0 0 0
0 0 M 0 0 0 M 0 0
,
0 0 L 0 0 0 L 0 0
0 0 0 0 0 M 0 M 0
L 0 0 0 M 0 0 0 K
0 0 0 0 0 L 0 L 0
,
0 0 0 0 0 N 0 N 0
0 0 N 0 0 0 N 0 0
0 N 0 N 0 0 0 0 0
0 0 0 0 0 0 0 0 0
0 -Q 0 -P 0 0 0 0 0
0 0 0 0 0 P 0 Q 0
,
0 P 0 Q 0 0 0 0 0
0 0 Q 0 0 0 P 0 0
,
-R 0 0 0 R 0 0 0 0
,
R 0 0 0 0 0 0 0 -R
0 0 0 0 0 0 0 0 0
,
0 0 0 0 0 -Q 0 -P 0
0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0
,
>
,
>
,
>
After each group was symbolized, its Symbolizations were given the name SymbolRules[gp], before the next SymbolizeProjectio639 Tijk overwrote it. For instance, look at parts 1 through 3:
Symmetry Theory
After each group was symbolized, its Symbolizations were given the name SymbolRules[gp], before the next SymbolizeProjection Tijk overwrote it. For instance, look at parts 1 through 3: SymbolRules@"D3d"DP1 ;; 3T ::A ® 1
T@x, x, xD -
4
:B ® :C ®
1
T@x, y, yD -
4 1 2 1
T@x, y, zD T@x, z, yD -
2
1
T@y, x, yD -
4
1 T@y, y, xD>, 4
1 T@y, x, zD>, 2 1 T@y, z, xD>> 2
If you see things like SymbolRules@"D2d"DP1 ;; 3T
88A ® v06<, 8B ® v08<, 8C ® v11<<
it means that axial permutation rules have been invoked, and you will have to work a little harder to answer your question. The answer is somewhere before MakeTijkDisplay was invoked.
46.6 Axis permutation forbiddenness Some of the results for the Platonic groups are quite surprising, and seem to be a new discovery. Here we review one of them step by step. Look at the detailed projection of species Ea of group T: tracePrj = TraceProjectTijk@"T"D; detPrjTEa = DetailedProjectTijk@tracePrjDP2, 2T; Short@%, 9D
640
Axis permutation forbiddenness :Ea, ::80, 0, 0<, :0, 0,
1
T@x, y, zD -
1
T@y, z, xD 6 ä T@y, z, xD 1 ä T@z, x, yD - T@z, x, yD + >, 6 2 3 2 3 1 1 ä T@y, x, zD :0, T@x, z, yD - T@y, x, zD 3 6 2 3 1 ä T@z, y, xD T@z, y, xD + , 0>>, 81<, 6 2 3 1 ::0, 6 + T@1D, 0>, 81<, 80, 0, 0<>>> 3 3
This is a non-zero result, and was not filtered out by the all-zero filter in Trace ProjectTijk. Now put in the axis permutation symmetry: detPrjTEa . xyzCyclicRules
8Ea, 8880, 0, 0<, 80, 0, 0<, 80, 0, 0<<, 880, 0, 0<, 80, 0, 0<, 80, 0, 0<<, 880, 0, 0<, 80, 0, 0<, 80, 0, 0<<<<
As in the two-photon tensors, it appears that in group T the transition A ® Ea is forbidden. On your own Do the same thing for species Eb. Then do Ega and Egb in groups Th , and do the E species in O, Oh and Td , and the H species of group I. You will find surprising vanishings in all of them. Species H of I is particularly weird, as only two of its five components vanish.
46.7 End Notes 46.7.1. Rotation formula for three-index tensors Closed; please read from CD
46.7.2. Derivation of axis permutation rules Closed; please read from CD
641
47. Class sums and their products Preliminaries
47.1 Motivation This is the first of two chapters that teach the automated construction of character tables. In the analysis of flexible molecules you may need a character table that is not tabulated in this book or any book. Such molecules can be analyzed using permutation groups, but there are so many permutation groups that no one tabulates their character tables. When you need the character table of a permutation group, you usually have to make it yourself. This is a treacherous and uncertain job by hand, but the Mathematica automation offered here will do any group without requiring human thought at all. All you need to know about the group is its multiplication table. This topic requires an idea not treated by most applied group theory books; namely, the idea of a group algebra. In this chapter, we will define group algebra and use it to define a class sum, then prove some surprising and beautiful little theorems about class sums and their products. We end this chapter with the automated construction of the class sum multiplication table (the CSMT). In the next chapter we will show how to construct the character table of the group, using only the CSMT.
47.2 Declaration of a "group algebra" By postulate, group elements possess a pairwise group operator conventionally called “multiplication”, but nothing in the group postulates assures us that we can take linear combinations of group elements. But they do not prevent it, either. Group algebra So now we announce as a separate postulate that we are going to allow linear combinations of group elements. Any set of elements on which multiplication and linear combination are permitted is called “an algebra”. Linear combinations of group elements are not members of the group (they do not appear in the closed multiplication table), W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, 643 DOI 10.1007/b13137_47, © Springer Science+Business Media, LLC 2009
Symmetry Theory
members of the group (they do not appear in the closed multiplication table), but they will quickly prove themselves interesting and useful. You may think of the group elements as the basis vectors of a space, and linear combinations of group elements as points in the space. We call this space the “group space”. Multiplication of two points of the group space is defined as ordinary scalar multiplication of numerical coefficients, with group theoretical multiplication of group elements (with preservation of the given order). Therefore it needs a special symbol that is neither * nor Ä. We choose the Diamond, , which in Mathematica is undefined. Multiplication of two points in group space Using Greek letters for numerical coefficients and Latin capitals for group elements (… + Α A + … )(… + Β B+ … ) = (… + (Α *Β) ( A Ä B) + … ) On the right side we intend for Α*Β and A Ä B to be actually carried out, each according to its own rules.
47.3 Class sums One set of points in the group space will be of great interest to us. They are the class sums, defined as the sum of all the group elements in a class. The notation we will use is Class sum notation All class sums will be denoted by a DoubleStruck capital C, with a subscript indicating the class. If class A is 8A1 , ¼, Am <, its class sum will be CA = A1 + ¼+ Am . Often the class names are just C1 , C2 , etc. Class sum multiplication is just a special case of group point multiplication, defined above, but it is so important that we write it explicitly :
644
Class sums
Class sum multiplication If CA = A1 + ¼+Am is one class sum and CB = B1 + ¼+ Bn is another, the class sum product is
CA CB = HA1 + ¼+ Am L HB1 + ¼+ Bn L A1 Ä B1 + ¼+ Am Ä Bn This is just a normal algebraic expansion, but with preservation of factor order.
47.4 ClassSum theorems Class sums have some remarkable properties that we will need. Here they are. 1. Every class sum CA commutes with every element M of the group. This is written as M CA = CA M. Multiply on the right by M-1 : M CA M-1 = CA , and expand the C's to give M A1 M-1 + ¼ + M An M-1 = A1 +¼+An Look back at Theorem 4, Chapter 20, to justify that equality. See if you can argue it on from here. If you get confused, you can always click here.
2. All the class sums in a group commute with each other. This is easy in light of the theorem above. As usual, start by writing the theorem in symbols : CA CB = CB CA . Expand just one of the sums: HA1 + ¼+ An L CB = CB HA1 + ¼+ An L A1 CB + ¼+ An CB = CB A1 + ¼+ CB An But by Theorem 1, the first term on the left is the same as the first term on the right; etc. So q.e.d.
645
Symmetry Theory
3. The product of two class sums is unchanged if similarity transformed by any member Gk of the group. Since Gk Gk -1 is the unit element, we can write the first equality below: the second and third equalities are true because Gk commutes with both CA and CB (Theorem 1).
CA CB = CA CB IGk Gk -1 M = CA Gk CB Gk -1 = Gk HCA CB L Gk -1
4. The product of two class sums is a linear combination of class sums, with integer coefficients. In symbols, CA CB = Ú ΒM CM nC
M=1
where nC is the number of classes and the ΒM are integers. The proof is a bit long. It follows below. Proof of Theorem 4: Let CA = A1 +¼+Am and CB = B1 + ¼+ Bn , and expand the class sums: CA CB = HA1 + ¼+ Am L HB1 + ¼+ Bn L = A1 B1 + ¼+ Am Bn But each element product on the right is a single element of the group. Collect them into class sums as far as possible
CA CB = â Αm Cm + Βr Gr + ¼ nC
m=1
where Αm is the number of times class Cm occurs in the product, and Gr is one of several leftovers after all possible class sums have been collected together. It is left over Βr times, etc. But by Theorem 3, above, this is unchanged if we similarity transform it by some element Gp . -1 CA CB = Gp â Αm Cm G-1 p + Βr Gp Gr Gp + ¼ nC
m=1
But by Theorem 4 of Chapter 20 , classes are invariant under similarity transforms. Therefore, so are class sums, and we can write
646
Class sum theorems
CA CB = â Αm Cm + Βr IGp Gr G-1 p M+¼ nC
m=1
Let Gs be a member of the class of Gr that is not among the leftovers. But there must be some Gp in the group such that Gp Gr G-1 p = Gs so for this Gp we have
CA CB = â Αm Cm + Βr Gs + ¼ nC
m=1
But this is a contradiction, since Gs was specifically not among the leftovers. So there can be no leftovers. Also the Αm are integers (class counts), and we have CA CB = â Αm Cm nC
m=1
which was to be proved.
47.5 Class sum multiplication for a familiar group We want to make a class sum multiplication table for a familiar group. Pick one, and begin by constructing its group multiplication table: gp = "T"; MT = MultiplicationTable@Dot, CartRep@gpD, Range@GroupOrder@gpDDD; % GridForm 1 2 3 4 5 6 7 8 9 10 11 12
2 9 6 8 7 11 10 12 1 5 3 4
3 7 8 6 9 10 11 1 12 4 2 5
4 6 9 7 8 12 1 11 10 3 5 2
5 8 7 9 6 1 12 10 11 2 4 3
6 10 12 11 1 5 3 2 4 8 9 7
7 12 10 1 11 2 4 5 3 9 8 6
8 11 1 10 12 4 2 3 5 6 7 9
Here 1 stands for the first group element in the CartRep; 2, for the second; etc. Now construct the class list, using the same integer name code:
647
Symmetry Theory
toIntegerNames = Thread@ElementNames@gpD ® Range@GroupOrder@gpDDD; CL = Classes@gpD . toIntegerNames 881<, 82, 3, 4, 5<, 86, 7, 8, 9<, 810, 11, 12<<
We relied above on the operators CartRep and Classes, which produced respectively, the MT in standard order and the CL in standard order. This will produce, in the end, a character table with its columns (but not its rows) in standard order, making it fairly easy to compare our construction with the standard character table. But on a desert island you would not have this help, so in the last section of the next chapter we will construct the character table of an untabulated group so you can see (1) that it can be done, and (2) the issues that arise when there is no standard order for anything.
47.6 The ClassSumProduct operator 47.6.1 Step by step construction We want to make a function with the calling expression ClassSumProduct[n1,n2,CL,MT] where n1 is the class number of one class; n2, the other; CL is the class list; and MT is the group multiplication table. To be concrete, we take the class sum product of class number 2 with class number 3, step by step. The inputs are n1 = 2; n2 = 3; We will need the lengths of the two classes:
8len1, len2< = Map@Length, 8CLPn1T, CLPn2T
Now multiply each element in class number n1 by each element of class number n2. We use the old integer name trick, pulling the product name directly from the integer-named multiplication table: expr1 = Table@MTPCLPn1, iT, CLPn2, jTT, 8i, 1, len1<, 8j, 1, len2
648
ClassSumProduct operator 810, 12, 11, 1, 12, 10, 1, 11, 11, 1, 10, 12, 1, 11, 12, 10<
These are the summands of the class sum product. The definition now says to add them up, but they are just integers and we do not want them to add in the arithmetic sense. So protect them by wrapping them with an undefined head Q : expr2 = expr1 . n_Integer ® Q@nD
8Q@10D, Q@12D, Q@11D, Q@1D, Q@12D, Q@10D, Q@1D, Q@11D, Q@11D, Q@1D, Q@10D, Q@12D, Q@1D, Q@11D, Q@12D, Q@10D<
Now we can safely add them :
expr3 = expr2 . List ® Plus 4 Q@1D + 4 Q@10D + 4 Q@11D + 4 Q@12D
All this has been collected into a single operator named ClassSumProduct, defined in the preliminaries We demonstrate it: ClassSumProduct@n1, n2, CL, MTD 4 Q@1D + 4 Q@10D + 4 Q@11D + 4 Q@12D
This is the same as expr3, above. By Theorem 4, it must be a linear combination of class sums, with integer coefficients. So we need an operator that will recognize classes automatically. Fortunately, with Mathematica's pattern recognition abilities this is not too hard. We do it in the next section.
47.6.2 From sum of elements to the symbolic class sum In the preliminaries we defined an operator MakeTagRules that generates the appropriate rules : tagRules = MakeTagRules@CLD
8Q@1D ® C1 , Q@2D ® -Q@3D - Q@4D - Q@5D + C2 , Q@6D ® -Q@7D - Q@8D - Q@9D + C3 , Q@10D ® -Q@11D - Q@12D + C4 <
Look carefully. Each rule replaces the first element in each class by the class name minus the other class elements. After using this rule and expanding, all the element names cancel and you are left only with the class name, times the appropriate numerical factor. expr3 . tagRules Expand 4 C1 + 4 C4
There is the symbolic answer we wanted. The Expand after application of the tagRules is very important; this is what causes the cancellation of the Qwrapped element names. Take it away and rerun. You will see. 649
47.7 ClassSumMultiplicationTable
Symmetry Theory
47.7 ClassSumMultiplicationTable Now we are ready for mass production of class sum products. CSMT = Table@ClassSumProduct@i, j, CL, MTD, 8i, 1, nC<, 8j, 1, nC
C2 4 C3 4 C1 + 4 C4 3 C2
C3 4 C1 + 4 C4 4 C2 3 C3
C4 3 C2 3 C3 3 C1 + 2 C4
In the next chapter we will verify that this is correct, by showing that it leads to the correct character table. The construction of the CSMT that you just saw above has been condensed into a single operator ClassSumMultiplicationTable[mltTbl_]. It is in the preliminaries. Test it: CSMT == ClassSumMultiplicationTable@MTD True
In the next chapter, you will learn how to turn the class multiplication table into the essential square part of the character table. In other words, we will determine the traces of all the irreducible representation matrices without ever knowing the matrices themselves.
47.8 End Notes 47.8.1 Theorem 1, finished We left off with M A1 M-1 + M A2 M-1 + ¼ + M an M-1 = A1 +A2 +¼+An where no two of the elements Ai are the same. There are n summands on both sides. But by the referenced theorem, every summand on the left belongs to the class, and therefore is the same as some summand on the right. The only way the equation could fail is if two terms on the left were the same. So assume that two terms on the left are the same: M Ai M-1 = M Ak M-1 . Then left multiply by M-1 and right multiply by M, and you are left with Ai = Ak . 650 But by hypothesis all the Ai are different. Contradiction.
End Notes
So assume that two terms on the left are the same: M Ai M-1 = M Ak M-1 . Then left multiply by M-1 and right multiply by M, and you are left with Ai = Ak . But by hypothesis all the Ai are different. Contradiction. Therefore, the left side is just a reordering of the right side, and every class sum commutes with every element of the group, as was to be shown.
651
48. Make a character table Preliminaries
48.1 Introduction This is the second of two chapters that teach the automated construction of character tables. In the last chapter we showed how to construct the class sum multiplication table (CSMT), using only information in the group multiplication table (GMT). In this chapter we will construct the character table, using only information in the CSMT.
48.2 Make the CSMT again Partly as review, and partly to get ourselves started again, we work quickly down to where we left off in the last chapter, at the ClassSumMultiplica tionTable (CSMT). You can use any tabulated group, but we continue on with group T, as in the last chapter. gp = "T"; At the end, you will be encouraged to run other groups. Most groups use Dot as the group multiplication operator, but a few groups need special multiplication operators. We choose them automatically for the groups that need them: dotOp = Which@ gp == "I", IcosaDot, gp == "C5", PentaDot, gp == "D5", PentaDot, gp == "D5h", PentaDot, gp == "D5d", PentaDot, True, DotD Dot
Remember, IcosaDot and PentaDot work just like Dot, except that they also resolve some format ambiguities in the output. Construct the multiplication table :
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137_48, © Springer Science+Business Media, LLC 2009
653
Symmetry Theory
MT = MultiplicationTable@dotOp, CartRep@gpD, Range@GroupOrder@gpDDD; % GridForm 1 2 3 4 5 6 7 8 9 10 11 12
2 9 6 8 7 11 10 12 1 5 3 4
3 7 8 6 9 10 11 1 12 4 2 5
4 6 9 7 8 12 1 11 10 3 5 2
5 8 7 9 6 1 12 10 11 2 4 3
6 10 12 11 1 5 3 2 4 8 9 7
7 12 10 1 11 2 4 5 3 9 8 6
8 11 1 10 12 4 2 3 5 6 7 9
CSMT = ClassSumMultiplicationTable@MTD; % GridForm C1 C2 C3 C4
C2 4 C3 4 C1 + 4 C4 3 C2
C3 4 C1 + 4 C4 4 C2 3 C3
C4 3 C2 3 C3 3 C1 + 2 C4
This is where we left off in the previous chapter.
48.3 Class sum product coefficients We showed, as Theorem 5 of Chapter 47, that Ca Cb = Ú Βm Cm . This is nC
m=1
a fine equation, but computation-oriented people will notice that something is a little wrong with it. Free indices a and b on the left specify which product of class sums you mean, but they do not appear on the right. This is easily corrected. We make it read Ca Cb = Ú ca,b,m Cm nC
(48.1)
m=1
We let ca,b,m be the “class sum product coefficients” (CSPC). They are easily lifted out of the CSMT. As always, we start with something easy and build up. First, we find all the CSPC's for just one row of the CSMT (we take row 2). The row itself is 654
Class sum product coefficients
CSMTrow2 = CSMTP2T
8C2 , 4 C3 , 4 C1 + 4 C4 , 3 C2 <
The variables that occur in these expressions are listed in the first row (provided the first class is the unit class) : CDvars = CSMTP1T 8C1 , C2 , C3 , C4 <
Each expression in CSMTrow4 is linear in the CDvars (as assured by Theorem 5 of Chapter 47) so the matrix relating them can be found by CSPCrow2 = MatrixOfCoefficients@CSMTrow2, CDvarsD; % GridForm 0 0 4 0
1 0 0 3
0 4 0 0
0 0 4 0
Check this: CSPCrow2.CDvars == CSMTrow2 True
Yes, it had to work. The number of classes will be nC. Run it over all rows : nC = Length@CSMTD; CSPC = Table@MatrixOfCoefficients@ CSMTPiT, CDvarsD, 8i, 1, nC
1 0 0 0
0 1 0 0
0 0 1 0
0 0 0 1
0 4 0 0
0 0 4 0
1 0 0 3
0 4 0 0
,
0 0 4 0
1 0 0 3
0 4 0 0
0 0 4 0
,
0 0 0 3
0 3 0 0
0 0 3 0
1 0 0 2
,
>
There is the whole three-index array ca,b,m . For maximum resemblance to the definition, Eq. 48.1, (click to see it again) we make a function definition for each array element : Clear@c, a, b, mD;
655
Symmetry Theory
8a, 1, nC<, 8b, 1, nC<, 8m, 1, nC
Do@ca_,b_,m_ := CSPCPa, b, mT,
If you get an error above, it is probably because subscripted quantities were Symbolized when you ran a different chapter. We want this in most chapters, but not here. Quit Mathematica and do this chapter in a fresh session of its own. The symbolization of subscripts is blocked in this chapter.
Make sure the indices of the c functions work as variables :
CSPC == Table@cr,s,t , 8r, 1, nC<, 8s, 1, nC<, 8t, 1, nC
Since class sums commute, the c array should be symmetric in its first two indices : Table@cr,s,t == cs,r,t , 8r, 1, nC<,
8s, 1, nC<, 8t, 1, nC
8True<
In the coming calculation we will need the populations of the classes, symbolized as Pi : Clear@PD; Plist = Table@Pi , 8i, 1, nC
popList = Map@Length, Classes@gpDD 81, 4, 4, 3<
toPops = Thread@Plist ® popListD 8P1 ® 1, P2 ® 4, P3 ® 4, P4 ® 3<
48.4
A strategy for the character table
The definition of the CSPC, Eq. 48.1, is written in terms of class sums. But we are more interested in class characters than class sums. All the matrices in any given class have the same character, so the trace of the class sum i is just the population of class i HPi L times Χs,i , the character of class i: Trace@Ci D == Pi Χs,i
Putting this into Eq. 48.1, we have the master equation for the characters of the 656 group (Bunker and Jensen, Eq. 5-69, p. 80 )
Strategy
Putting this into Eq. 48.1, we have the master equation for the characters of the group (Bunker and Jensen, Eq. 5-69, p. 80 ) IPi Χs,i M I Pj Χs,j M == Χs,1 ÚnC k=1 ci,j,k Pk Χs,k
(48.2)
where Pi is the population of class i; Χs,c is the character of class c in species s; in particular, Χs,1 is the character of class 1 in species s. Class 1 is always the class of the unit element, which contains only a single matrix; namely, a unit matrix of appropriate dimension. In other words, Χs,1 is the dimension of species s. We know how to calculate the c and P quantities from the multiplication table of the group, so the unknowns of Eq. 48.2 are all the Χ quantities; i.e., the character table. If we could solve that equation, the problem would be finished. However, it is homogeneous of degree 2 in the Χ's, so it will give us only relative values, not absolute values. In other words, the master equation will give us the character vector of each species, except that one character must remain symbolic. (We will let it be Χs,1 , the dimension of the species.) So for the complete solution, we will need another relation. Fortunately, the row and column orthogonalities of the character table give us the additional relations we need. So our strategy will have two steps: first we solve the master equation, finding the characters of each species expressed in terms of the species dimension. Then we will use the column orthogonality to get the species dimensions, and the solution will be complete and exact.
48.5
Use the master equation
Put the known values of the c and P quantities into the master equation : ΧEqsRaw = UnionB FlattenBTableBPi Pj Χs,i Χs,j Χs,1 â ci,j,k Pk Χs,k , nC
k=1
8i, 1, nC<, 8j, 1, nC
9True, 16 Χ2s,2 16 Χs,1 Χs,3 , 16 Χs,2 Χs,3 4 Χ2s,1 + 12 Χs,1 Χs,4 , 16 Χ2s,3 16 Χs,1 Χs,2 , 12 Χs,2 Χs,4 12 Χs,1 Χs,2 ,
12 Χs,3 Χs,4 12 Χs,1 Χs,3 , 9 Χ2s,4 3 Χ2s,1 + 6 Χs,1 Χs,4 =
Get rid of the tautology :
657
Symmetry Theory
ΧEqsRaw2 = Select@ΧEqsRaw, ð =!= True &D; Column@ΧEqsRaw2D 16 Χ2s,2 16 Χs,1 Χs,3 16 Χs,2 Χs,3 4 Χ2s,1 + 12 Χs,1 Χs,4 16 Χ2s,3 16 Χs,1 Χs,2 12 Χs,2 Χs,4 12 Χs,1 Χs,2 12 Χs,3 Χs,4 12 Χs,1 Χs,3 9 Χ2s,4 3 Χ2s,1 + 6 Χs,1 Χs,4
Let's count equations and variables. For each species
8nEqs, nVars< = 8Length@ΧEqsRaw2D, nC< 86, 4<
So for nC species, the total number of equations and variables is nC * 8nEqs, nVars< 824, 16<
So there is redundancy; more equations than variables. This is not a problem for Mathematica as long as all the equations are self-consistent. The Reduce operator will give you the complete story: reducedΧEqsRaw = Reduce@ΧEqsRaw2D LogicalExpand HΧs,2 0 && Χs,3 0 && -3 Χs,4 Χs,1 L ÈÈ HΧs,1 0 && Χs,2 0 && Χs,3 0 && Χs,4 0L ÈÈ Χ2s,3 Χs,4 Χ2s,3 Χs,4 Χ2s,3 Χs,4
Χs,2 && Χs,4 Χs,1 && Χs,4 Χs,3 && Χs,4 ¹ 0 ÈÈ Χs,2 && Χs,4 Χs,1 && -H-1L13 Χs,4 Χs,3 && Χs,4 ¹ 0 ÈÈ Χs,2 && Χs,4 Χs,1 && H-1L23 Χs,4 Χs,3 && Χs,4 ¹ 0
This is a little easier to read if we get rid of the logical And and Or operators: ΧEqs2 = reducedΧEqsRaw . Or ® List . And ® List
:8Χs,2 0, Χs,3 0, -3 Χs,4 Χs,1 <,
8Χs,1 0, Χs,2 0, Χs,3 0, Χs,4 0<, ,
658
Use the master equation
:
Χ2s,3
:
Χ2s,3
:
Χ2s,3
Χs,4
Χs,4
Χs,4
Χs,2 , Χs,4 Χs,1 , Χs,4 Χs,3 , Χs,4 ¹ 0>,
Χs,2 , Χs,4 Χs,1 , -H-1L13 Χs,4 Χs,3 , Χs,4 ¹ 0>, Χs,2 , Χs,4 Χs,1 , H-1L23 Χs,4 Χs,3 , Χs,4 ¹ 0>>
The all-zero solution is worthless. No species has dimension Χs,1 0, so use this test to discard : ΧEqs3 = Select@ΧEqs2, FreeQ@ð, Χs,1 == 0D &D
:8Χs,2 0, Χs,3 0, -3 Χs,4 Χs,1 <, :
Χ2s,3
:
Χ2s,3
:
Χ2s,3
Χs,4
Χs,4
Χs,4
Χs,2 , Χs,4 Χs,1 , Χs,4 Χs,3 , Χs,4 ¹ 0>,
Χs,2 , Χs,4 Χs,1 , -H-1L13 Χs,4 Χs,3 , Χs,4 ¹ 0>, Χs,2 , Χs,4 Χs,1 , H-1L23 Χs,4 Χs,3 , Χs,4 ¹ 0>>
The condition Χs,_ ¹ 0 does not help with the solutions, so we might as well get rid of it too. Make a selection list based on the absence on an inequality: selector = Map@FreeQ@ð, a_ ¹ b_D &, ΧEqs3, 82
88True, True, True<, 8True, True, True, False<, 8True, True, True, False<, 8True, True, True, False<<
Now Pick will pull out only those elements that correspond to a True : ΧEqs = Pick@ΧEqs3, selectorD
:8Χs,2 0, Χs,3 0, -3 Χs,4 Χs,1 <, :
Χ2s,3
:
Χ2s,3
:
Χ2s,3
Χs,4
Χs,4
Χs,4
Χs,2 , Χs,4 Χs,1 , Χs,4 Χs,3 >, Χs,2 , Χs,4 Χs,1 , -H-1L13 Χs,4 Χs,3 >, Χs,2 , Χs,4 Χs,1 , H-1L23 Χs,4 Χs,3 >>
Each equation set specifies the character vector for a different species. The number of equations sets should therefore be equal to nS, or equivalently, to nC: 659
Symmetry Theory
Length@ΧEqsD == nC True
Each equation set contains nC-1 equations in nC variables, so we can only solve for nC-1 variables. In all species the one we pick to remain unsolved is Χs,1 , the dimension of the species. Here is how we implement this decision: Make a list called unks, the unknowns to solve for: ΧVars = Table@Χs,i , 8i, 1, nC
unks = Drop@ΧVars, 1D 8Χs,2 , Χs,3 , Χs,4 <
Now just call Solve : solnsRaw = Map@Solve@ð, unksDP1T &, ΧEqsD FullSimplify ::Χs,2 ® 0, Χs,3 ® 0, Χs,4 ® 8Χs,2 ® Χs,1 , Χs,3
>, 3 ® Χs,1 , Χs,4 ® Χs,1 <, Χs,1
:Χs,2 ® H-1L23 Χs,1 , Χs,3 ® -H-1L13 Χs,1 , Χs,4 ® Χs,1 >,
:Χs,2 ® -H-1L13 Χs,1 , Χs,3 ® H-1L23 Χs,1 , Χs,4 ® Χs,1 >>
After all this work, it is good to check for consistency of the putative solution: Table@ΧEqsPiT . solnsRawPiT Simplify, 8i, 1, nC
If you see {True} consistency is verified. The character table, still with unknown species dimension, is now in the form unnormalizedChVecs = ΧVars . solnsRaw Simplify; % GridForm 0
0
Χs,1
Χs,1
Χs,1
Χs,1
-H-1L13 Χs,1
Χs,1
23
Χs,1
Χs,1 Χs,1
H-1L23 Χs,1 13
-H-1L
Χs,1
H-1L
-
Χs,1
This is as far as we can go without more equations.
660
Χs,1
Χs,1
3
Use column orthogonality
48.6
Use column orthogonality
In the first row we need Χs,1 ® Χ1,1 ; in the second row we need Χs,1 ® Χ2,1 ; etc. Each row is linear in Χs,1 , so if we multiply each row by its own variable and the set Χs,1 to 1, we get just what we want : Χs1List = Table@Χs,1 , 8s, 1, nC
Χs1Mat = DiagonalMatrix@Χs1ListD; chVecs2 = Χs1Mat.unnormalizedChVecs . Χs,1 ® 1; % GridForm
0
0
Χ2,1
Χ2,1
Χ2,1
Χ2,1
-H-1L13 Χ3,1
Χ3,1
Χ3,1
H-1L23 Χ3,1
Χ4,1
-H-1L13 Χ4,1
-
Χ1,1
Χ1,1
H-1L23 Χ4,1
3
Χ4,1
Now use column orthogonality:
â nS
PC h
PD
Ö Χs,C
Χs,D == ∆C,D
h
s=1 Ö * . where Χs,C is ΧC,s
PD h
Let
Χs,D be Xmat.
Then the left side is
Ö
Xmat .Xmat. In words: If each column of the character table is weighted by the square root of the quantity (class population Pclass divided by group order h), then the columns of Xmat are orthonormal in the complex sense. h = GroupOrder@gpD; classWtFactors = TableB :
1
1 ,
2
3
1 ,
3
1 ,
3
2
Pi h
, 8i, 1, nC
>
Those powers of -1 in chVecs2 are generally complex, and we need to make them explicit, in the form a_+ ä b_ : chVecs3 = ; 661
Symmetry Theory
chVecs2 ComplexExpand Collect@ð, Χs_,1 D &;
% GridForm Χ1,1
0
0
Χ2,1
Χ2,1
Χ2,1
Χ3,1
- 12 +
ä
Χ4,1
- 12 -
ä
3 2 3 2
Χ3,1
- 12 -
ä
Χ4,1
- 12 +
ä
-
Χ1,1 3
Χ2,1
3
Χ3,1
Χ3,1
3
Χ4,1
Χ4,1
2
2
We must multiply each column (each class) by its own classWtFactor. We can accomplish this by multiplication with a diagonal matrix. But does it go on the left or the right? Make a test: M = 88a, b, c<, 8d, e, f<, 8g, i, j<<; D = DiagonalMatrix@8A, B, C
aA Ad Ag
bB Be Bi
cC Cf Cj
,
aA Bd Cg
Ab Be Ci
Ac Bf Cj
>
Column multiplication is given by M.D; the diagonal matrix goes on the right: Xmat = chVecs3.DiagonalMatrix@classWtFactorsD Simplify; % GridForm Χ1,1 2
Χ2,1 2
Χ2,1
Χ2,1
3 ä ä+
3
Χ4,1 2
0
3
Χ3,1 2
-
0
3
3
Χ3,1
2
2
ä -ä+
3
2
3
-
3
ä -ä+
3
2
3
-
Χ4,1
ä ä+ 2
6
Χ2,1
3
3
Χ1,1
3 3
Χ3,1
Χ3,1 2
Χ4,1
Χ4,1 2
To take the dot products of the rows “in the complex sense”, we need the conjugate transpose XmatÖ , which we dot with Xmat: XmatÖ = Transpose@ Xmat . Complex@a_, b_D ® Complex@a, -bDD;
colOrthog = dotOpAXmat, XmatÖ E ComplexExpand ToRadicals; % GridForm 662
Use column orthogonality
Χ21,1
0
0
0
Χ22,1
0
0
0
Χ23,1
0
0
Χ24,1
9
0 0 0
0
If it is not diagonal, something is wrong. By the column orthogonality theorem, it must be a unit matrix. So set all the diagonal elements to 1, and Solve. dimEqs = Thread@Diagonal@colOrthogD == 1D :
Χ21,1 9
1, Χ22,1 1, Χ23,1 1, Χ24,1 1>
dimSolnsRaw = Map@Solve, dimEqsD Flatten 8Χ1,1 ® -3, Χ1,1 ® 3, Χ2,1 ® -1, Χ2,1 ® 1, Χ3,1 ® -1, Χ3,1 ® 1, Χ4,1 ® -1, Χ4,1 ® 1<
The answer is the dimension of the species, which must always be positive. Select out the negative solutions : dimSolns = Select@dimSolnsRaw, HðP2T > 0L &D 8Χ1,1 ® 3, Χ2,1 ® 1, Χ3,1 ® 1, Χ4,1 ® 1<
At last, here is our main goal, the character table :
ourChVecs1 = chVecs3 . dimSolns ComplexExpand; % GridForm 3 1
0 1
1
- 12 +
ä
1
-2 -
1
ä
48.7
-1 1
0 1 3 2 3 2
- 12 -
ä
1
ä
-2 +
3 2 3 2
1 1
Final formatting
Some groups (namely, D5 h and maybe others) need a little help with the formatting of expressions that contain noRoot5InDenom:
5.
We provide it by the rule
663
Symmetry Theory
noRoot5InDenom = 2 : ® -1 2 + 1+ 5
5 2,
® 12 -
-2 1+
5 2 >;
5
If dotOp is not Dot, but rather PentaDot or IcosaDot, the character vectors above may also contain other radical expressions that need to be brought into standard form. The following ruse does it, because PentaDot and Icosadot have the desired cleanup machinery inside them : ourChVecs = HdotOp@IdentityMatrix@nCD, ourChVecs1D ComplexExpandL . noRoot5InDenom; % GridForm 3 1
0 1
1
- 12 +
ä
1
- 12 -
ä
-1 1
0 1 3 2 3 2
- 12 -
ä
- 12 +
ä
3 2 3 2
1 1
This is the answer, with radicals (if any) in standard format. Do these rows all occur in the standard character table, and if so, in what order ? stdChVecs = ChVecs@gpD ComplexExpand; speciesPerm = Map@Position@ourChVecs, ðD &, stdChVecsD Flatten 82, 4, 3, 1<
If speciesPerm is a permutation of the first nC integers, there is complete agreement. So the character table in standard order is ourChVecsPspeciesPermT; % GridForm 1 1
- 12 -
ä
1
- 12 +
ä
3
664
1
1 3 2
0
3 2
- 12 +
ä
- 12 -
ä
1 3 2
0
3 2
1 1 -1
Final formatting
On your own Go back to the top and change gp to any other group in the GroupCat alog. It should run down to here automatically. Groups tested by the author: I, C5 , D5 , D5 h , D5 d , D6 h , C3 v The slowest step is often the calculation of the multiplication table.
48.8 Character table of a new group 48.8.1 Make group D8 and its MultiplicationTable In the character table constructions above, we drew on the standard CartRep for the basic group of matrices, which was arranged by classes in conventional order. This made it easy to compare the calculated result with the standard result. Here we will show what else you have to do when dealing with a newly constructed group that has nothing in any conventional order. Our example will be group D8 , a reasonably useful group not included in our tabulations. (Our tabulation of the Dn groups stops at n = 6.) For a standard character table of this group, see Cotton, 3rd ed., p. 432, upper left quadrant of his table for D8 h . Construct group D8 : rawD8 = MakeGroup@Dot, 8Cz @2 Π 8D, Cx @2 Π 2D
881, 0, 0<, 80, 1, 0<, 80, 0, 1<<
However, nothing else is in any particular order. Make its multiplication table : rawMTD8 = MultiplicationTable@Dot, rawD8, Range@16DD; % GridForm Size@7D
665
Symmetry Theory
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
2 1 5 6 3 4 9 10 7 8 13 14 11 12 16 15
3 4 1 2 7 8 5 6 11 12 9 10 15 16 13 14
4 3 7 8 1 2 11 12 5 6 15 16 9 10 14 13
5 6 2 1 9 10 3 4 13 14 7 8 16 15 11 12
6 5 9 10 2 1 13 14 3 4 16 15 7 8 12 11
7 8 4 3 11 12 1 2 15 16 5 6 14 13 9 10
8 7 11 12 4 3 15 16 1 2 14 13 5 6 10 9
9 10 6 5 13 14 2 1 16 15 3 4 12 11 7 8
10 9 13 14 6 5 16 15 2 1 12 11 3 4 8 7
11 12 8 7 15 16 4 3 14 13 1 2 10 9 5 6
This multiplication table is the sole source of information about the group that we use in the rest of this construction.
48.8.2 Operators that use only the MT In order to create a character table for a group known only by its multiplication table, we will need an element multiplication operator and an element inverse operator that work by reference to only the raw multiplication table. In the special preliminaries for this chapter, we define such operators. The multiplication operator is called TimesByTbl[name1,name2,tbl]. What does it predict for the value of 3 Ä 2, using rawMTD8 as the lookup table? TimesByTbl@3, 2, rawMTD8D 5
To verify this, locate 3 in the first column and 2 in the first row, and look for the intersection of their respective row and column. It has to agree, because TimesByTbl looked it up just like you did. We can also find inverses using InverseByTbl[name_, tbl_]: inv9 = InverseByTbl@9, rawMTD8D 8
Check it with TimesByTbl@9, inv9, rawMTD8D == 1 True
666
Character table of a new group
On your own Check all inverses by running this check over the whole group. Hint: Table is one way.
The TimesByTbl and InverseByTbl operators were created so we could write ClassifyByTbl to find the classes of the group without knowing anything but its multiplication table. It works just like the Classify operator that you are familiar with : rawCLD8 = ClassifyByTbl@rawMTD8D 881<, 82, 7, 10, 15<, 83, 6, 11, 14<, 84, 5<, 88, 9<, 812, 13<, 816<<
As you see, this group is greatly in need of some tidying up. Normally, groups are listed so that classes come together. Here they are scattered all over.
48.8.3 Tidy the group up; name the classes Making the group tidy is not necessary, but in this didactic exercise it helps in the end when we want to compare our calculated result to the known result. And even for totally untabulated groups you probably will want to name the classes and put them in some semi-logical order. That is what we do next. The first element in each class is classFirsts = Map@First, rawCLD8D 81, 2, 3, 4, 8, 12, 16<
Map@RecognizeMatrix@rawD8PðTD &, classFirstsD; % Column 8identity< 8rotation, 2-fold, 881, 0, 0<, Π<< :rotation, 2-fold, ::
2+
2
, 1, 0>, Π>>
9rotation, 8-fold, 980, 0, -1<, 2
9rotation, 4-fold, 980, 0, -1<,
Π == 4 Π == 2
:rotation, 2.66667-fold, :80, 0, -1<, 8rotation, 2-fold, 880, 0, 1<, Π<<
3Π >> 4
On the basis of these matrix types, we assign class names: 1. E the identity 2. C¢2 four horizontal two-fold rotations, one being the x-axis ¢ 3. C¢¢ 2 another four horizontal two-folds, between the C2 axes 4. C8 two z-rotations by 1 ´ 5. C4 two z-rotations by 2 ´ 3
2Π , 8 2Π , 8 2Π
one in each sense one in each sense
667
Symmetry Theory
On the basis of these matrix types, we assign class names: 2. C¢2 four horizontal two-fold rotations, one being the x-axis ¢ 3. C¢¢ 2 another four horizontal two-folds, between the C2 axes 2Π , 8 2Π two z-rotations by 2 ´ 8 , two z-rotations by 3 ´ 28Π , one z-rotation by 4 ´ 28Π
4. C8 two z-rotations by 1 ´
one in each sense
5. C4
one in each sense
6.
C38
7. C2
one in each sense
3 rawClassNames = 9E, C¢2 , C¢¢ 2 , C8 , C4 , C8 , C2 =
9E, C2 ¢ , C2 ¢¢ , C8 , C4 , C38 , C2 =
Cotton gives the order of these classes as {1,4,6,5,7,2,3}. It will be easier to verify the final result if we put the classes in this order. newCL = rawCLD8P81, 4, 6, 5, 7, 2, 3
Permute the names the same way : newClassNames = rawClassNamesP81, 4, 6, 5, 7, 2, 3
It is now easy to permute the list of matrices so that classes come together: newElPerm = Flatten@newCLD
81, 4, 5, 12, 13, 8, 9, 16, 2, 7, 10, 15, 3, 6, 11, 14<
newD8 = rawD8PnewElPermT; On your own Run RecognizeMatrix over newD8 to see that the group is in fact “tidy”. With the group in a new order, we must redo its multiplication table: newMTD8 = MultiplicationTable@Dot, newD8, Range@16DD; % GridForm Size@7D
668
Character table of a new group
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
2 6 1 8 7 4 3 5 13 15 14 16 10 9 12 11
3 1 7 6 8 2 5 4 14 13 16 15 9 11 10 12
4 8 6 7 1 5 2 3 15 16 13 14 12 10 11 9
5 7 8 1 6 3 4 2 16 14 15 13 11 12 9 10
6 4 2 5 3 8 1 7 10 12 9 11 15 13 16 14
7 3 5 2 4 1 8 6 11 9 12 10 14 16 13 15
8 5 4 3 2 7 6 1 12 11 10 9 16 15 14 13
9 14 13 16 15 11 10 12 1 7 6 8 3 2 5 4
10 13 15 14 16 9 12 11 6 1 8 7 2 4 3 5
11 16 14 15 13 12 9 10 7 8 1 6 5 3 4 2
Verify that the elements are now arranged by classes in conventional class order: newCLD8 = ClassifyByTbl@newMTD8D
881<, 82, 3<, 84, 5<, 86, 7<, 88<, 89, 10, 11, 12<, 813, 14, 15, 16<<
Now the classes are in Cotton' s order. The order of the elements within each class is still uncontrolled, but we do not care about that.
48.8.4 Character table for group D8 To bring things to a rapid conclusion, we now copy into a single cell all the operations from Section 48.2 to Section 48.6, eliminating everything extraneous, so that it will go through with a single hit. newCSMT = ClassSumMultiplicationTable@newMTD8D; nC = Length@newCSMTD; newCDvars = newCSMTP1T; newCSPC = Table@MatrixOfCoefficients@newCSMTPiT, newCDvarsD, 8i, 1, nC
k=1
8j, 1, nC
ΧEqsRaw2 = Select@ΧEqsRaw, ð =!= True &D; reducedΧEqsRaw = Reduce@ΧEqsRaw2D LogicalExpand; ΧEqs2 = reducedΧEqsRaw . Or ® List . And ® List; ΧEqs3 = SelectAΧEqs2, FreeQAð, Χs,1 == 0E &E; selector = Map@FreeQ@ð, a_ ¹ b_D &, ΧEqs3, 82
669
Symmetry Theory
ΧEqs = Pick@ΧEqs3, selectorD; ΧVars = TableAΧs,i , 8i, 1, nC<E; unks = Drop@ΧVars, 1D; solnsRaw = Map@Solve@ð, unksDP1T &, ΧEqsD FullSimplify; unnormalizedChVecs = ΧVars . solnsRaw Simplify; Χs1List = TableAΧs,1 , 8s, 1, nC<E; Χs1Mat = DiagonalMatrix@Χs1ListD; chVecs2 = Χs1Mat.unnormalizedChVecs . Χs,1 ® 1; h = Length@newMTD8D; classWtFactors = TableB
Pi
, 8i, 1, nC
h
Xmat = chVecs2.DiagonalMatrix@classWtFactorsD Simplify; XmatÖ = Transpose@Xmat . Complex@a_, b_D ® Complex@a, -bDD; colOrthog = Xmat.XmatÖ ; dimEqs = Thread@Diagonal@colOrthogD == 1D; dimSolnsRaw = Map@Solve, dimEqsD Flatten; dimSolns = Select@dimSolnsRaw, HðP2T > 0L &D; ourChVecs = chVecs2 . dimSolns Reverse; ourChTable1 = Prepend@ourChVecs, newClassNamesD; % GridForm
E
C8
C38
C4
C2
C2 ¢
C2 ¢¢
1 1 1 1
1 -1 1 -1
1 -1 1 -1
1 1 1 1
1 1 1 1
1 -1 -1 1
1 1 -1 -1
2
2
- 2
0
-2
0
0
0 -2
-2 2
0 0
0 0
2 2
- 2 0
2 0
Comparison with Cotton shows that the rows are correct, but of course the order of the rows was determined by the solving operators. For exact agreement with Cotton, we need to permute the rows. rowPerm = 81, 2, 4, 5, 3, 6, 8, 7<; ourChTable = ourChTable1ProwPermT; % GridForm E
C8
C38
C4
C2
C2 ¢
C2 ¢¢
1 1 1 1
1 1 -1 -1
1 1 -1 -1
1 1 1 1
1 1 1 1
1 -1 1 -1
1 -1 -1 1
2 2
2 0
- 2 0
0 -2
-2 2
0 0
0 0
0
-2
0
0
2
- 2
2
Eyeball comparison against Cotton shows exact agreement. You may want to name the species as well as the classes. For this, use the Mulliken names as much as possible, as expounded in Chapter 28. In this case they should be, respectively A1 , A2 , B1 , B2 , E1 , E2 , E3 . But many physicists do not bother 670 with the Mulliken names, assigning to species the meaningless names G1 , G2 , etc.
Eyeball comparison against Cotton shows exact agreement. You ofmay want to Character table a new group name the as well as the classes. For use the Mulliken names as respectively A1 , A2 , B1 , B2 , E1 , E2 , E3 . But many physicists do not bother with the Mulliken names, assigning to species the meaningless names G1 , G2 , etc.
671
A1. Mathematica packages This computational chapter may be read from the CD that accompanies the book
W.M. McClain, Symmetry Theory in Molecular Physics with Mathematica, DOI 10.1007/b13137, © Springer Science+Business Media, LLC 2009
673
A2. SymbolizeExpressions This computational chapter may be read from the CD that accompanies the book
675
A3. Matrix review This computational chapter may be read from the CD that accompanies the book
677
B1. Bibliography Preliminaries
B1.1. Wolfram Research, Inc. 1. See the WorldWideWeb site of Wolfram Research Inc., the developers of Mathematica, at http://www.wolfram.com .
2. Stephen Wolfram, The Mathematica Book, 3rd ed., 1403 pages. (Wolfram Media / Cambridge University Press, 1998). This entire book is available online in Mathematica version 3.0 and later.
3. Wolfram MathWorld, "the web's most extensive mathematics resource. Created, developed & nurtured by Eric Weisstein, with input from the world's mathematics community".
B1.2. Applied group theory books 4. Eugene Wigner, Group Theory and its application to the quantum mechanics of atomic spectra , Academic Press (New York, N.Y.) 1959. First edition, in German, 1931.
5. Morton Hamermesh, Group Theory and its application to physical problems, Addison-Wesley, (Reading, MA) 1962.
6. Volker Heine, Group Theory in Quantum Mechanics, An introduction to its present usage , Pergamon Press (New York, NY) 1960.
7. Leo M. Falicov, Group Theory and Its Physical Applications , University of Chicago Press (Chicago, IL) 1966. Notable for its concise proofs of all the important theorems. Tragically out of print for many years. Good libraries have it.
8. F. Albert Cotton, Chemical Applications of Group Theory , John Wiley and Sons (New York, NY) First edition 1963, Third edition1990. Library of Congress number QD461.C65 1990.
9. George H. Duffey, Applied Group Theory for Physicists and Chemists , Prentice-Hall (Englewood Cliffs NJ) 1991. Library of Congress number QD174.17.S9D84 1991. Duffey explains Cayley diagrams for groups, as well as class sums. These topics are missing 679 from most group theory applications books.
Symmetry Theory
9. George H. Duffey, Applied Group Theory for Physicists and Congress number QD174.17.S9D84 1991. Duffey explains Cayley diagrams for groups, as well as class sums. These topics are missing from most group theory applications books.
10. Philip R. Bunker and Per Jensen, Molecular Symmetry and Spectroscopy, Second Edition, NRC Research Press, Ottawa (1998). Library of Congress number QD461.B86 1998. Bunker and Jensen are unique in emphasizing the permutation group approach to physical applications. This permits them to treat flexible molecules (molecules that invert, or that have internal rotors) which are impossible to treat under the standard point group approach.
B1.3. Mathematica books For a comprehensive, up-to-the-minute listing of Mathematica tutorial books, go to http://store.wolfram.com/catalog/books/tut-ref.html , a part of the Wolfram website. Here are my personal favorites:
11. Stan Wagon, Mathematica in Action, 3rd ed. (Springer Verlag, 2008). A very current book making extensive use of the new Version 6 graphics and manipulations operators. Wagon is famous for his summer tutorials "Rocky Mountain Mathematica", in Frisco, Colorado. About 600 pages, with CD-ROM.
12. Nancy Blachman and Colin P. Williams, Mathematica: A Practical Approach, 363 pages. (Prentice Hall, 1999). Excellent for beginners; look for a forthcoming edition 2008 or later.
13. John W. Gray, Mastering Mathematica: programming methods and applications (Academic Press Professional, 1994). John W. Gray is Professor of Mathematics at the University of Illinois, and is the father of Theo Gray, chief designer of Mathematica's Front End. This book starts from the beginning with Mathematica and carries on to some very sophisticated mathematical materials at the end. Of special interest to Symmetry Theory is his section on Polya pattern analysis.
14. And of course the grandfather of them all, Stephen Wolfram, The Mathematica Book, 3rd ed. The definitive reference for pre-6 versions. See Section B1.1, above.
B1.4. Chemistry and Physics books 680
Chemistry and Physics books
B1.4. Chemistry and Physics books 15. E. Bright Wilson, Jr., J. C. Decius, and Paul C. Cross, Molecular Vibrations (McGraw-Hill, 1955; Dover Publications, Inc. 1980). 388 pages. This may have been the first Chemistry book to make systematic use of group theory.
16. L. Pauling and E. B. Wilson, Introduction to quantum mechanics (McGraw-Hill, New York, 1935), Atomic term symbols are on pp. 230-234.
17. A. R. Edmonds, Angular Momentum in Quantum Mechanics (PrincetonUniversity Press, Princeton, N.J.) Second edition, 1960, 146 pages. A concise derivation and presentation of many complex formulas related to the full rotation group, remarkably free of error.
18. G. Herzberg, Molecular Spectra and Molecular Structure, 3 volumes, (Prentice-Hall, 1939)
19. Condon, E. U., and Shortley, G.H., The Theory of Atomic Spectra (Cambridge University Press (1935)). Their phase convention for the spherical harmonics has become standard, and is linked to the Euler angle convention used in this book.
20. Landau, L. D. and Lifschitz, E. M., Quantum Mechanics - Nonrelativistic Theory, Second Ed., , Pergamon Press, Addison-Wesley Publishing Co., Reading, Mass. (1965).
21. Greiner, W. and Müller, B., Quantum Mechanics - Symmetries, Second Ed., Springer Verlag (1994).
22. Peter F. Bernath, Spectra of Atoms and Molecules, Oxford University Press (1995)
23. J.J. Sakurai, Modern Quantum Mechanics, Revised Ed., San Fu Tuan, ed., Addison Wesley Publishing Co. (1994). Wigner-Eckhardt is on pp. 238 - 242.
24. J.J. Sakurai, Advanced Quantum Mechanics, Benjamin/Cummings Publ. Co. (1967)
25. Hans A. Bethe, Intermediate Quantum Mechanics, based on notes by Roman Jackiw, W. A. Benjamin (1964)
26. G. F. Koster, J. O. Dimmock, R. G. Wheeler, and H. Statz, Properties of the 32 Crystal Point Groups, MIT Press (1963) 681
Symmetry Theory
26. G. F. Koster, J. O. Dimmock, R. G. Wheeler, and H. Statz, Properties of the 32 Crystal Point Groups, MIT Press (1963)
B1.5. Math books 27. Margenau, Henry, and Murphy, George M.,., The Mathematics of Physics and Chemistry, van Nostrand & Co., New York, N.Y.. (1943, 1955). Matrices and Matrix Algebra, Ch. 10.
28. Perlis, Sam., Theory of Matrices,, Addison-Wesley Publishing Co., Reading, Mass. (1952). Block diagonal multiplication, pp. 15-16.
29. Isaacs, I. Martin, Character Theory of Finite Groups, Academic Press, New York (1976)
30. Coxeter, H. S. M., Regular Polytopes, Methuen, London, (1948) 31. Jeffreys, Harold, Sir, Cartesian Tensors, Cambridge, Eng. : The University Press (1931), 92 p. (reprinted 1961) Succinct and powerful.
32. Buck, R, Creighton , Advanced Calculus, McGraw-Hill (1956)
B1.6. Data collections 33. Moore, Charlotte E., Bibliography on the analyses of optical atomic spectra; Sec. I, Hydrogen - Vanadium; Sec. 2, ChromiumNiobium; Sec. 3, Molybdenum - Lanthanum and Hafnium - Actinium; Sec. 4, Lanthanum - Lutecium and Actinium - Einsteinium. U.S. National Bureau of Standards; for sale by the Supt. of Docs., U.S. Govt. Print. Ofc., Washington, 1968-69.
B1.7. Research papers 34. A. M. Schönflies, Über Gruppen von Transformationen des Raumes in sich, Math. Ann. 34, 172 –203 (1889)
35. L. Pauling, 682
J. Am. Chem. Soc. 53, 1367 (1931)
Research papers
35. L. Pauling, J. Am. Chem. Soc. 53, 1367 (1931)
36. M. Göppert-Mayer, Ann.(Leipzig) 5, 9, 273 (1931)
37. Longuet-Higgins, H. C. Mol. Phys. 6, 445 (1963)
38. W. M. McClain and R. A. Harris, in Excited States, Volume 3, E. C, Lim, Ed., Academic Press. (1977) pp. 2-56.
39. Spiro, T. G. and Streakas, T. C. , Proc. Nat. Acad. Sci. U.S.A., 69, 2622 (1972) http://www.pnas.org/cgi/reprint/69/9/2622.pdf
40. Robert F. Curl and John E. Kilpatrick, Am. J. Phys. 28, 357-365 (1960)
41. W. Heisenberg, Ann. Phys. 120, 888 (1931)
683
Index
Analyze[ ], 444 associativity, verification of, 85 AxialRotation[axis,angle], 158 axiom associative, 57 closure, 56 inverse element, 57, 61 unit element, 56 Bedrock Corollary, 485 Bedrock Theorem, general, 484 Block diagonal multiplication, 372 Born-Oppenheimer states, symmetry of, 549 buckminsterfullerene, 265 Cartesian representation construction Axial groups, 225 orientation conventions, 219 Platonic groups, 231 Cartesian representation operators, GroupCatalog[ ], 219 character of a class, definition, 294 character table bases for irreducible representations, 180 general description, 173 –174 character table has an inverse, 439 character table is square, 439 character table operators BoxedCharacterTable["group"], 185
685
Symmetry Theory
BoxedCharacterTable["group"], 179 CharacterTable["group"], 181 Classes[ ], 181 ClassNames[ ], 181 ClassPopulations[ ], 181 ElementNames[ ], 181 SpeciesNames[ ], 181 TabulatedBases[ ], 181 class, sum theorems, 645 class, definition, 295 Classify[ ], 300 ClassSumMultiplicationTable[ ], 649 column orthogonality, 436 Constellate[ ], 252 constellation I , 264 Ih , 266 CP[ ] (blue ContoutPlot), 329 d- squared corollary, 453 Degeneracy in quantum mechanis, 319 DirectProduct[matA,matB], 551 EulerAngles[mat], 143 EulerMatrix[ f,q,y], 141 fullerene, C60 , stereo view, 265 function transform, definition, 329 Fundamental theorem of symmetry theory, 73 Gould, Stephen Jay, biologist, 79 group names International, 209 Schönflies, 207 GroupCatalog[ ], 217 groups of matrices, under Dot, 60 of numbers, under Times, 59 of permutations, under Permute, 63 redundant, 96 Hamiltonian symmetry theorem, 309 handedness, definition, 42 hybrid orbitals, 521 Lagrange's theorem coset lemma, 286 proof, 288 Latin square
686
Index
Latin square converse, 84 theorem, 83 linear combinations of degenerate orbitals, 314 MakeClass[ ], 294 MakeGroup[mats], development, 183 MakeLines[ ], 252 MakeRegularRep[ ], 451 MakeSALCs[ ], 504 matrix element, quantum mechanical, 483 molecules CenterOfMass[ ], 102 AtomGraphics[ ], 104 BondGraphics[ ], 104 DistanceMatrix[ ], 106 EnclosingRadius[ ], 103 graphics, AxialViews[ ], 110 graphics, StereoViews[ ], 109 in Mathematica, definition, 99 InertiaTensor[ ], 103 ListToMolecule[ ], 101 MolecularWeight[ ], 102 MoleculeCatalog[ ], 102 MOtoStandardForm[ ], 527 Movies of degenerate function spaces, E1g orbitals of benzene, 317 MultiplicationTable[ ], 90 NeatProjection[ ], 526 Permute[ ], 64 Platonic solids, 231 point group elements inversion matrix, 114 proper and improper, 132 reflection, 31 rotation, angular, 143 rotation, axial, 157 roto-reflection matrix, 118 unit matrix, 113 point groups, definition, 134 polarization vectors, optical, 565 power sequnces in groups, 77 product group theorem, for pseudocommutation, 204 theorem, for true commutation, 201 projection operators full formula, 464 ProjectED[ ] demo, 474
687
Symmetry Theory
ProjectED[ ] demo, 466 ProjectET[ ] demo, 460 trace formula, 462 Rearrangement theorem, 84 reflection, definition, 31 regular rep, golden property, 452 regular representation, 449 representation, faithful, 89 representation theory congruent reps, 343 faithful and unfaithful reps, 336 Great Orthogonality in skewer language, 421 Great Orthogonality in subscript language, 423 Great Orthogonality proof, 427 invariance of rep bases, 339 MakeRepAtomic[ ], 369 MakeRepDisplacement[ ], 541 MakeRepMolec[ ], 358 MakeRepPoly[ ], 359 MakeRepRot[ ], 363 MorphTest[ ], 337 Mulliken names of irreducible reps, 375 reducible and irreucible, 374 rep construction recipe, 339 representation definition, 335 Schur's first lemma, 407 Schur's ReduceRep[ ] operator, 404 Schur's second lemma, 415 skewers, 421 universal commuter for one rep, 352 universal pseudocommuter for two reps, 347 Rotational eigensystem theorem, 163 rotoinversion, 209 RoundSort[ ], 191 RoundUnion[ ], 192 row orthogonality long, 435 short, weighted, 436 SALC (SymmetryAdaptedLinearCombination), 507 sign convention, axis-angle, 167 similarity transform, defitinition of, 292 subgroups and symmetry breaking, 274, 279 definition, 279 orientation issue, 273 Subgroups["group"], 272 symmetry
688
Index
symmetry algebraic, 46 general definition, 29 geometric, 30 symmetry analysis procedure, 443 ToReImParts[ ], 477 transition oscillations, movie, 570 two-photon tensor patterns, table, 593, 613 tensors, 577 unitary representations balancing a basis set, 387 MakeUnitary[ ], 394 unitary similarity theorem, 390 VibrationalAnbalysis[ ], 545 ziggurat, 473
689