teresia173 2020-01-12 20:26 采纳率: 100%
浏览 704
已采纳

python类内部的方法调用

class Adaboosting中demo_train方法中要调用同个类中的loadDataSet方法,但是根本没进到程序之中,求教是什么原因,谢谢大佬们了
demo_train的代码如下

        def demo_train(self):
                print("已进入到了内部函数")
                print(self.model)
                if self.model==None:
                        self.model="test.txt"
                dataArr, LabelArr = self.loadDataSet(self.model)
                weakClassArr, aggClassEst = Adaboosting.adaBoostTrainDS(dataArr, LabelArr)
                # from my_adaboosting_SVM_ROC import adaClassify
                print("正在训练模型...")
                predictions = self.adaClassify(dataArr, weakClassArr)
                errArr = np.mat(np.ones((len(dataArr), 1)))
                number=1-float(errArr[predictions != np.mat(LabelArr).T].sum() / len(dataArr) * 100)
                print('训练集的错误率:%.3f%%' % float(errArr[predictions != np.mat(LabelArr).T].sum() / len(dataArr) * 100))
                # print("33333333")
                print(self.train)
                if self.train==None:
                        self.train="test6.txt"
                # print("444444444")
                print(self.train)
                # train = "test6.txt"
                testArr, testLabelArr = self.loadDataSet(self.train)
                predictions = self.adaClassify(testArr, weakClassArr)
                print(predictions)
                errArr = np.mat(np.ones((len(testArr), 1)))
                number1=1-float(errArr[predictions != np.mat(testLabelArr).T].sum() / len(testArr) * 100)
                print('测试集的错误率:%.3f%%' % float(errArr[predictions != np.mat(testLabelArr).T].sum() / len(testArr) * 100))
                from my_adaboosting_SVM_ROC import plotROC
                plotROC(aggClassEst.T, LabelArr)
                return number ,number1

loadDataSet的代码如下

        # 导入数据
        def loadDataSet(fileName):
                print("hhhhhhhhhhhhhhhhh")
                numFeat = len((open(fileName).readline().split('\t')))
                dataMat = [];
                labelMat = []
                fr = open(fileName)
                for line in fr.readlines():
                        lineArr = []
                        curLine = line.strip().split('\t')
                        for i in range(numFeat - 1):
                                lineArr.append(float(curLine[i]))
                        dataMat.append(lineArr)
                        labelMat.append(float(curLine[-1]))

                return dataMat, labelMat

运行结果:
图片说明

  • 写回答

2条回答 默认 最新

  • wrenthomas 2020-01-13 14:20
    关注
    def loadDataSet(self,fileName):
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥20 matlab计算中误差
  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料
  • ¥15 使用R语言marginaleffects包进行边际效应图绘制
  • ¥20 usb设备兼容性问题
  • ¥15 错误(10048): “调用exui内部功能”库命令的参数“参数4”不能接受空数据。怎么解决啊