2010-06-12 4 views
2

Je suis déconcerté par la collision de nom suivant:C++, collision nom à travers différents espaces de noms

namespace mp2 { 

boost::numeric::ublas::matrix_range<M> 
slice(M& m, const R1& r1, const R2& r2) { 
    namespace ublas = boost::numeric::ublas; 
    ublas::range r1_(r1.begin(), r1.end()), r2_(r2.begin(), r2.end()); 
    return ublas::matrix_range<M>(m, r1_, r2_); 
} 

double energy(const Wavefunction &wf) { 
    const Wavefunction::matrix& C = wf.coefficients(); 
    int No = wf.occupied().size(); 

    foreach (const Basis::MappedShell& P, basis.shells()) { 
     slice(C, range(No), range(P)); 

l'erreur de g ++ 4.4 est

7 In file included from mp2.cpp:1: 
8 /usr/include/boost/numeric/ublas/fwd.hpp: In function âdouble mp2::energy(const Wavefunction&)â: 
9 /usr/include/boost/numeric/ublas/fwd.hpp:32: error: âboost::numeric::ublas::sliceâ is not a function, 
10 ../../src/mp2/energy.hpp:98: error: conflict with âtemplate<class M, class R1, class R2> boost::numeric::ublas::matrix_range<M> mp2::slice(M&, const R1&, const R2&)â 
11 ../../src/mp2/energy.hpp:123: error: in call to âsliceâ 
12 /usr/include/boost/numeric/ublas/fwd.hpp:32: error: âboost::numeric::ublas::sliceâ is not a function, 
13 ../../src/mp2/energy.hpp:98: error: conflict with âtemplate<class M, class R1, class R2> boost::numeric::ublas::matrix_range<M> mp2::slice(M&, const R1&, const R2&)â 
14 ../../src/mp2/energy.hpp:129: error: in call to âsliceâ 
15 make: *** [mp2.lo] Error 1 

segment uBLAS est

namespace boost { namespace numeric { namespace ublas { 
    typedef basic_slice<> slice; 

pourquoi une tranche dans ublas entre en collision avec une tranche dans mp2? Je et assez certain, il n'y a pas using namespace ublas dans le code et comprend.

merci

+0

désolé, il y avait des messages de compilateur étrangers retirés – Anycorn

+0

avez-vous une instruction using n'importe où? –

+0

@Dav non, je n'en ai trouvé aucun. Je regarde à travers ublas comprend, ils semblaient être bien aussi – Anycorn

Répondre

2

Je pense qu'il ya argument-dependent lookup passe.

slice(C, range(No), range(P)); 

Deux arguments range sont apparemment de boost::numeric::ublas (probablement importé avec using boost::numeric::ublas::range;), de sorte que le compilateur considère les noms forment cet espace de noms, ce qui inclut le type slice en elle.

Questions connexes