X-Git-Url: https://ginac.de/ginac.git//ginac.git?a=blobdiff_plain;f=ginac%2Fcolor.cpp;h=21bf507186a78c822d50a4615358e6cf39d79ee2;hb=695f6ae955ec530cded8f21efd5569df39447f76;hp=e06eff44a43c659ef7bb7567f6dc04fdffc03961;hpb=23acc666fcef311fd97092aee7f8c55e80395351;p=ginac.git diff --git a/ginac/color.cpp b/ginac/color.cpp index e06eff44..21bf5071 100644 --- a/ginac/color.cpp +++ b/ginac/color.cpp @@ -3,7 +3,7 @@ * Implementation of GiNaC's color (SU(3) Lie algebra) objects. */ /* - * GiNaC Copyright (C) 1999-2004 Johannes Gutenberg University Mainz, Germany + * GiNaC Copyright (C) 1999-2005 Johannes Gutenberg University Mainz, Germany * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -527,12 +527,32 @@ static bool is_color_tinfo(unsigned ti, unsigned char rl) return ti == (TINFO_color + rl); } -ex color_trace(const ex & e, unsigned char rl) +/** Check whether a given tinfo key (as returned by return_type_tinfo() + * is that of a color object (with an arbitrary representation label). */ +static bool is_color_tinfo(unsigned ti) +{ + return (ti & ~0xff) == TINFO_color; +} + +/** Extract representation label from tinfo key (as returned by + * return_type_tinfo()). */ +static unsigned char get_representation_label(unsigned ti) +{ + return ti & 0xff; +} + +ex color_trace(const ex & e, const std::set & rls) { if (is_a(e)) { - if (ex_to(e).get_representation_label() == rl - && is_a(e.op(0))) + unsigned char rl = ex_to(e).get_representation_label(); + + // Are we taking the trace over this object's representation label? + if (rls.find(rl) == rls.end()) + return e; + + // Yes, all generators are traceless, except for color_ONE + if (is_a(e.op(0))) return _ex3; else return _ex0; @@ -543,8 +563,8 @@ ex color_trace(const ex & e, unsigned char rl) ex prod = _ex1; for (size_t i=0; i(e)) { - if (!is_color_tinfo(e.return_type_tinfo(), rl)) - return _ex0; + unsigned char rl = get_representation_label(e.return_type_tinfo()); - // Expand product, if necessary + // Are we taking the trace over this string's representation label? + if (rls.find(rl) == rls.end()) + return e; + + // Yes, expand product if necessary ex e_expanded = e.expand(); if (!is_a(e_expanded)) - return color_trace(e_expanded, rl); + return color_trace(e_expanded, rls); size_t num = e.nops(); @@ -597,11 +620,32 @@ ex color_trace(const ex & e, unsigned char rl) } else if (e.nops() > 0) { // Trace maps to all other container classes (this includes sums) - pointer_to_map_function_1arg fcn(color_trace, rl); + pointer_to_map_function_1arg &> fcn(color_trace, rls); return e.map(fcn); } else return _ex0; } +ex color_trace(const ex & e, const lst & rll) +{ + // Convert list to set + std::set rls; + for (lst::const_iterator i = rll.begin(); i != rll.end(); ++i) { + if (i->info(info_flags::nonnegint)) + rls.insert(ex_to(*i).to_int()); + } + + return color_trace(e, rls); +} + +ex color_trace(const ex & e, unsigned char rl) +{ + // Convert label to set + std::set rls; + rls.insert(rl); + + return color_trace(e, rls); +} + } // namespace GiNaC