2023(春)Python程序设计作业5:Pandas基础技能及综合应用

软工213-492-楚昀哲 2023-春-学生 2023-06-22 15:22:21

一、实验要求

  • 学习unittest的基本概念和用法

  • 能够独立编写unittest测试用例

  • 熟悉测试驱动开发(TDD)思想

二、实验环境说明

  • 操作系统:Windows/Linux/MacOS

  • Python版本:3.x

  • 集成开发环境:可选,建议使用PyCharm

三、实验目的

  • 掌握Python中的单元测试框架unittest的使用方法

  • 理解测试驱动开发(TDD)的基本思想和流程

  • 培养编写高质量代码的习惯

四、实验题目

1.要求三角型的三个边长:A、B 和C(最大值不超过100)。当三边不可能构成三角形时提示错误。若是等腰三角形打印“等腰三角形”,若是等边三角形,则提示“等边三角形”,其它情形则返回“一般三角形”。

2.完成:Python程序代码、设计测试用例(覆盖有效等价类、无效等价类),并给出基于unittest测试的代码。

1. triangle.py

class Triangle:
    def __init__(self, a, b, c):
        self.a = a
        self.b = b
        self.c = c
 
    def IsTriangle(self):
        if self.a + self.b > self.c and self.a + self.c > self.b and self.b + self.c > self.a:
            return True
        else:
            return False
 
    def getType(self):
        if self.IsTriangle():
            if self.a == self.b and self.b == self.c:
                return 
            elif self.a == self.b or self.a == self.c or self.b == self.c:
                return 
            else:
                return 
        else:
            return 

2.testtriangle.py

from triangle import Triangle
import unittest

class TestTriangle(unittest.TestCase):
    def setUp(self):
        pass

    def tearDown(self):
        pass

    def test_IsTriangle1(self):
        self.tri = Triangle(2, 3, 4)
        self.IsTriangle = self.tri.IsTriangle()
        self.assertEqual(self.IsTriangle, True)

    def test_IsTriangle2(self):
        self.tri1 = Triangle(5, 10, 20)
        self.IsTriangle1 = self.tri1.IsTriangle()
        self.assertEqual(self.IsTriangle1, False)

    def test_GetType1(self):
        self.tri2 = Triangle(3, 3, 3)
        self.assertEqual(self.tri2.getType(), "等边三角形")
        
    def test_GetType2(self):
        self.tri3 = Triangle(5, 5, 3)
        self.assertEqual(self.tri3.getType(), "等腰三角形")

    def test_GetType3(self):
        self.tri4 = Triangle(5, 4, 3)
        self.assertEqual(self.tri4.getType(), "一般三角形")

    def test_GetType4(self):
        self.tri5 = Triangle(5, 10, 20)
        self.assertEqual(self.tri5.getType(), "不构成三角形")

    def test_GetType5(self):
        self.tri6 = Triangle(3, 4, 5)
        self.assertEqual(self.tri6.getType(), "直角三角形")

    def test_GetType6(self):
        self.tri7 = Triangle(5, 12, 13)
        self.assertEqual(self.tri7.getType(), "直角三角形")

    def test_GetType7(self):
        self.tri8 = Triangle(5, 13, 12)
        self.assertEqual(self.tri8.getType(), "直角三角形")

    def test_GetType8(self):
        self.tri9 = Triangle(12, 5, 13)
        self.assertEqual(self.tri9.getType(), "直角三角形")

    def test_GetType9(self):
        self.tri10 = Triangle(12, 13, 5)
        self.assertEqual(self.tri10.getType(), "直角三角形")

    def test_GetType10(self):
        self.tri11 = Triangle(13, 5, 12)
        self.assertEqual(self.tri11.getType(), "直角三角形")

    def test_GetType11(self):
        self.tri12 = Triangle(3, 4, 6)
        self.assertEqual(self.tri12.getType(), "锐角三角形")

    def test_GetType12(self):
        self.tri13 = Triangle(3, 4, 2)
        self.assertEqual(self.tri13.getType(), "钝角三角形")

if __name__ == '__main__':
    suite = unittest.TestSuite()
    suite.addTest(TestTriangle("test_IsTriangle1"))
    suite.addTest(TestTriangle("test_IsTriangle2"))
    suite.addTest(TestTriangle("test_GetType1"))
    suite.addTest(TestTriangle("test_GetType2"))
    suite.addTest(TestTriangle("test_GetType3"))
    suite.addTest(TestTriangle("test_GetType4"))
    suite.addTest(TestTriangle("test_GetType5"))
    suite.addTest(TestTriangle("test_GetType6"))
    suite.addTest(TestTriangle("test_GetType7"))
    suite.addTest(TestTriangle("test_GetType8"))
    suite.addTest(TestTriangle("test_GetType9"))
    suite.addTest(TestTriangle("test_GetType10"))
    suite.addTest(TestTriangle("test_GetType11"))
    suite.addTest(TestTriangle("test_GetType12"))
    runner = unittest.TextTestRunner()
    runner.run(suite)
...全文
580 回复 打赏 收藏 转发到动态 举报
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复
内容概要:本文围绕“单相逆变器闭环逆变电路PWM模型仿真研究”展开,基于Simulink平台构建单相逆变器的闭环控制系统仿真模型,重点研究PWM调制技术在逆变电路中的应用与实现。文中详细阐述了系统架构设计、电压电流双闭环控制策略的实现原理、控制器参数设计及仿真建模全过程,并通过仿真结果验证了控制方案在动态响应、稳态精度与系统稳定性方面的有效性。同时,文档还涵盖多种电力电子系统典型应用场景,如多类型短路故障仿真(中性点不接地、经小电阻接地、经消弧线圈接地等)、软开关技术、微电网能量管理、MPPT控制等,体现出较强的技术综合性和工程实践价值。; 适合人群:电气工程、自动化、电力电子与新能源等相关专业的高校本科生、研究生、科研人员,以及从事电力系统仿真、逆变器设计与新能源并网技术研发的工程技术人员。; 使用场景及目标:①掌握基于Simulink的单相逆变器闭环控制系统建模与PWM仿真方法;②深入理解双闭环控制、SPWM/SVPWM调制、系统稳定性分析等核心技术原理;③为课程设计、毕业设计、科研项目或实际工程开发提供可复用的仿真模型与技术支持; 阅读建议:建议结合文中仿真模型动手实践,重点掌握PI控制器参数整定、PWM信号生成机制与仿真结果分析方法,同时可延伸学习文档中涉及的软开关、故障仿真、微电网控制等关联技术,以拓展系统级设计能力。

162

社区成员

发帖
与我相关
我的任务
社区描述
软件工程老师
python 高校 江苏省·南通市
社区管理员
  • juking@ntu
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧