forked from DanielLangr/UNtoU3
-
Notifications
You must be signed in to change notification settings - Fork 1
/
test_141.cpp
33 lines (31 loc) · 1.28 KB
/
test_141.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
// test_141.cpp - a test driver for UNtoU3 class.
//
// License: BSD 2-Clause (https://opensource.org/licenses/BSD-2-Clause)
//
// Copyright (c) 2019, Daniel Langr
// All rights reserved.
//
// Program implements the U(N) to U(3) reduction where n=2 (N=6) for the input irrep [2,1,1,1,1,0],
// which is represented by a number of twos n2=1, number of ones n1=4, and number of zeros n0=1.
// After reduction, the program iterates over generated U(3) weights and print level dimensionalities
// of those that represent U(3) irreps.
//
// The output should consist of 2 U(3) irreps having labels [5,4,3] and [6,4,2],
// both having level dimensionality 1.
#include <iostream>
#include "UNtoU3.h"
int main() {
UNtoU3<> gen;
// n=2 - a given HO level, N = (n+1)*(n+2)/2 = 6
gen.generateXYZ(2);
// generation of U(3) irreps in the input U(6) irrep
gen.generateU3Weights(1, 4, 1);
// iteration over generated U(3) weights
for (const auto & pair : gen.multMap()) {
// get U(3) weight lables
const auto & weight = pair.first;
// get its level dimensionality if its nonzero and the U(3) weight is a U(3) irrep
if (auto D_l = gen.getLevelDimensionality(weight))
std::cout << "[" << weight[0] << "," << weight[1] << "," << weight[2] << "] : " << D_l << "\n";
}
}