0

スタックオーバーフローの皆さん、こんにちは。

C++に関しては初心者です。クラスを作成しようとしましたが、もちろん、プログラムをコンパイルするとエラー メッセージが表示されます。私のプログラムのどこが間違っているのか、何が間違っているのかを教えてくれることを期待してここにいます!

PS : 私は OpenFOAM を使用しているため、".C" 拡張子 (".cpp" ではなく) や Foam ライブラリの使用など、いくつかの点が異なります。

容器.H

#ifndef Vessels_H
#define Vessels_H

// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //

class Vessels
{
public:

Vessels(double xCoordinate, double yCoordinate, double zCoordinate, double vesselLength, double vesselRadius, double P_outside, double P_inside);
int pointIndex();
double flowRate();
double wellModel();

private:

double m_xCoordinate, m_yCoordinate, m_zCoordinate, m_vesselLength, m_vesselRadius, m_P_outside, m_P_inside;
double flow, meshVolume, meshSize, equivalentRadius;
int index;

};

#include "Vessels.C"
#endif

容器.C

#include "Vessels.H"

// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //

// CONSTRUCTOR

Vessels::Vessels(double xCoordinate, double yCoordinate, double zCoordinate, double vesselLength, double vesselRadius, double P_outside, double P_inside) : m_xCoordinate(xCoordinate), m_yCoordinate(yCoordinate), m_zCoordinate(zCoordinate), m_vesselLength(vesselLength), m_vesselRadius(vesselRadius), m_P_outside(P_outside), m_P_inside(P_inside)
{

}

// METHODS 

// Corresponding index for point (xCoordinate,yCoordinate,zCoordinate)

int Vessels::pointIndex() 
{
    return mesh.findCell(point(m_xCoordinate,m_yCoordinate,m_zCoordinate));
}

// Calculation of flow rate in the vessel using the Hagen-Poiseuille equation

double Vessels::flowRate()
{
    return M_PI*Foam::pow(m_vesselRadius,4.0)/(8.0*mu.value*m_vesselLength)*(m_P_inside-m_P_outside);
}

// Numerical well model

double Vessels::wellModel()
{
    Vessels vessel(double xCoordinate, double yCoordinate, double zCoordinate, double vesselLength, double vesselRadius, double P_outside, double P_inside);
    index = vessel.pointIndex();
    flow = vessel.flowRate();
    meshVolume = mesh.V()[index];
    meshSize = Foam::pow(meshVolume,1.0/3);
    equivalentRadius = 3.0*meshSize/(3.0+2.0*M_PI*meshSize);

    m_P_inside = P[index] + mu.value*flow/(4.0*M_PI*K)*(1.0/equivalentRadius - 1.0/m_vesselRadius);
    return m_P_inside;
}

誰にとっても興味がある場合は、これまでの私のコンパイラ エラーを次に示します。

Vessels.C: In member function ‘double Vessels::flowRate()’:
Vessels.C:65:52: erreur: invalid operands of types ‘double’ and ‘<unresolved overloaded function type>’ to binary ‘operator*’
Vessels.C: In member function ‘double Vessels::wellModel()’:
Vessels.C:73:18: erreur: request for member ‘pointIndex’ in ‘vessel’, which is of non-class type ‘Vessels(double, double, double, double, double, double, double)’
Vessels.C:74:17: erreur: request for member ‘flowRate’ in ‘vessel’, which is of non-class type ‘Vessels(double, double, double, double, double, double, double)’
Vessels.C:79:35: erreur: invalid operands of types ‘<unresolved overloaded function type>’ and ‘double’ to binary ‘operator*’
Vessels.C: In member function ‘double Vessels::flowRate()’:
Vessels.C:66:1: attention : contrôle a atteint la fin non void de la fonction [-Wreturn-type]

ありがとう!C++ の使用方法をよりよく理解するために、可能な限りのアドバイスをお待ちしています。

4

3 に答える 3

1
Vessels vessel(double xCoordinate, double yCoordinate, double zCoordinate, double vesselLength, double vesselRadius, double P_outside, double P_inside);

これは関数の宣言であり、オブジェクトの宣言ではありません。オブジェクトのコピーを作成したいようですが、その理由がわかりません。取り除くだけです。

double Vessels::wellModel()
{
    index = pointIndex();
    flow = flowRate();
    meshVolume = mesh.V()[index];
    meshSize = Foam::pow(meshVolume,1.0/3);
    equivalentRadius = 3.0*meshSize/(3.0+2.0*M_PI*meshSize);

    m_P_inside = P[index] + mu.value*flow/(4.0*M_PI*K)*(1.0/equivalentRadius - 1.0/m_vesselRadius);
    return m_P_inside;
}

value は、次元化されたスカラーの値を抽出する関数です。

この場合、ここで括弧を忘れます:

return M_PI*Foam::pow(m_vesselRadius,4.0)/(8.0*mu.value()*m_vesselLength)*(m_P_inside-m_P_outside);
//                                                     ^^
于 2013-06-05T10:20:57.103 に答える
0

オブジェクトではなく、関数を作成していると思います

Vessel 容器 (double xCoordinate, double yCoordinate, double zCoordinate, double vehicleLength, double vehicleRadius, double P_outside, double P_inside);

于 2013-06-05T10:27:07.497 に答える