点-圆-圆柱类族的设计

/*  Copyright  (c)  2016*    All rights reserved  烟台大学计算机与控制工程学院

*    文件名称:3.cpp

*   作者:刘丽

*   完成日期:2016年 5  月 9日

*   版本号: v1.0

*
*【项目 - 点-圆-圆柱类族的设计】
按以下的提示,由基类的设计和测试开始,逐渐地完成各个类的设计,求出圆格柱体的表面积、体积并输出并且完成要求的计算任务:
(1)先建立一个Point(点)类,包含数据成员x,y(坐标点),实现需要的成员函数,并设计main函数完成测试;
(2)以Point为基类,派生出一个Circle(圆)类,增加数据成员r(半径),以及求面积的成员函数area,实现其他需要的成员函数,设计main函数完成测试;
(3)再以Circle类为直接基类,派生出一个Cylinder(圆柱体)类,再增加数据成员h(高),,以及求圆柱表面积的成员函数area和求圆柱体积的成员函数volume,实现需要的成员函数,并设计main函数完成测试。
要求编写程序,设计出各类中“需要的成员函数”,包括构造函数、析构函数、修改数据成员和获取数据成员的公共接口、用于输出的重载运算符“<<”函数等。
(提示:此任务可以分为三个子任务分成若干步骤进行。先声明基类,再声明派生类,逐级进行,分步调试。——这种方法适用于做任何的项目)


*/
#include<iostream>
#include<cstring>
const double PI=3.14;
using namespace std;
class Point
{
protected:
    int x;
    int y;
public:
    Point (int x,int y):x(x),y(y){};

};
Point ::Point(const Point &a)
{
    x=a.x;
    y=a.y;
}
class Circle:public Point
{
protected:
    int r;
public:
    Circle(int x,int y,int r):Point(x,y),r(r){};
    double getArea();


};
double Circle::getArea()
{
    return PI*r*r;
}
class Cylinder:public Circle
{
protected:
    int h;
public:
    Cylinder(int x,int y,int r,int h):Circle(x,y,r),h(h){};
    double getCArea();
    double getV();
};
double Cylinder::getCArea()
{
    return PI*r*r*2+2*PI*r*h;
}
double Cylinder::getV()
{
    return PI*r*r*h;
}
int main()
{
    Cylinder c1(0,0,2,5);
    cout <<"底面积为:"<<c1.getArea()<<endl;
    cout <<"表面积为:"<<c1.getCArea()<<endl;
    cout <<"体积为:"<<c1.getV()<<endl;

    return 0;
}








 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这是一个关于使用Python做圆柱绕流的Fluent学习笔记。卡门涡街是在定常不可压缩势流圆柱绕流中观察到的一种稳定的涡街现象。在这个问题中,我们可以使用Fluent软件模拟流体流动,并使用Python脚本来自动化模拟和数据分析。 以下是一个Python脚本示例,用于设置和运行Fluent模拟,并将结果保存到文件中: ```python import os # 设置Fluent环境变量 os.environ['FLUENT_HOSTNAME'] = 'localhost' os.environ['FLUENT_ARCH'] = 'lnamd64' os.environ['FLUENT_INC'] = '/usr/local/Fluent.Inc/fluent/fluent17.2.0' os.environ['FLUENT_LIB'] = '/usr/local/Fluent.Inc/fluent/fluent17.2.0/lib' # 导入Fluent模块 from fluent import * # 创建Fluent进程 fluent = Fluent() # 打开Mesh文件 fluent.meshRead('cylinder.msh') # 设置模拟参数 fluent.timeScheme('steady-state') fluent.physics('viscous') fluent.model('inviscid') fluent.material('air') fluent.viscosity(1.789e-5) fluent.density(1.225) fluent.referenceValues(1.0,1.0,1.0,1.0) # 定义边界条件 fluent.boundaryCondition('inlet', 'velocity-inlet', u=0.2, v=0.0, w=0.0) fluent.boundaryCondition('outlet', 'pressure-outlet', p=0.0) fluent.boundaryCondition('cylinder', 'wall') # 运行模拟 fluent.solve() # 保存结果 fluent.writeCase('cylinder.cas') fluent.writeData('cylinder.dat') ``` 在这个示例中,我们首先设置了Fluent环境变量,并导入了Fluent模块。然后,我们创建了一个Fluent进程,并打开了一个Mesh文件。接下来,我们设置了模拟参数、定义了边界条件,并运行了模拟。最后,我们保存了结果到文件中。 使用Python进行数据分析也非常方便。我们可以使用pandas库来读取和处理数据文件,并使用matplotlib库来绘制图形。以下是一个简单的Python脚本示例,用于读取和绘制圆柱绕流结果数据: ```python import pandas as pd import matplotlib.pyplot as plt # 读取数据文件 data = pd.read_csv('cylinder.dat', delim_whitespace=True, header=None, names=['x', 'y', 'z', 'u', 'v', 'w', 'p', 'c']) # 绘制速度云图 plt.contourf(data['x'].values.reshape(-1, 201), data['y'].values.reshape(-1, 201), data['u'].values.reshape(-1, 201)) plt.colorbar() plt.title('Velocity Contour') plt.xlabel('x') plt.ylabel('y') plt.show() # 绘制压力分布图 plt.plot(data['y'][::201], data['p'][::201]) plt.title('Pressure Distribution') plt.xlabel('y') plt.ylabel('p') plt.show() ``` 在这个示例中,我们使用pandas库读取了数据文件,并使用matplotlib库绘制了速度云图和压力分布图。这些图形可以帮助我们更好地理解流体流动的特性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值