Machine Learning 之简单绘制决策树

#encoding:utf-8
#
#基本绘图
#
import numpy as np
import cv2
import cv2.cv as cv
class Parent:
      def __init__(self,k,d):
            self.k=k
            self.d=d

class DrawTree:
      def __init__(self,data):
            self.data=data
            self.canvas= np.zeros((600,1000,3),dtype="uint8")
            self.color={'green':(0,255,0),'red':(0,0,255),\
                        'blue':(255,0,0),'white':(255,255,255)}
            self.font=cv.InitFont(cv.CV_FONT_HERSHEY_PLAIN, 1.3, 1.3, 0, 1, 1)
            p1=Parent(0,50)
            self.getTree(p1,data,0,0)


      def getTree(self,parent,data,k,i):
            k=k+1
            for i in range(len(list(data))):
                  if type(data[list(data)[i]])==type({0:1}):
                        self.putText(str(data.keys()[i]),k*120,parent.d+i*300/k,'white')
                        parent=Parent(k*120,parent.d+i*350/k)
                        self.getTree(parent,data[list(data)[i]],k,i)   
                  else:
                      self.putText(str(list(data)[i]),(k)*120,parent.d+i*300/k,'white')
                      self.putText(str(data[list(data)[i]]),(k+1)*120,parent.d+i*300/k,'green')

      def putText(self,text,x,y,index):
            self.canvas=cv.fromarray(self.canvas)
            cv.PutText(self.canvas, text, (x-len(str(text))*10/2,y),self.font,self.color[index])
            self.canvas=np.array(self.canvas)
            #cv2.rectangle(self.canvas,(x-15,y-30),(x+30,y+15),self.color['green'])

      def putLine(self,x1,y1,x2,y2):
            cv2.line(self.canvas,(x1,x2),(y1,y2),self.color['red'],2)

      def showSave(self,name):
            cv2.imwrite(name,self.canvas)
            cv2.imshow("Canvas",self.canvas)
            cv2.waitKey(0)



测试 test.py

data={'no surfacing':{0:{'ash':{0:{0:'nnnnnn'},1:'yyyyyy'}},1:{'flippers':{0:'no',1:'yes'}}}}
a=DrawTree(data)
a.showSave('1.jpg')
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值