首页 > 其他分享 >compress压缩模块功能测试

compress压缩模块功能测试

时间:2023-11-16 14:57:45浏览次数:29  
标签:index code str compress 功能测试 模块 line data cur

功能介绍

产生随机测试文本或者进行功能验证
功能验证指通过分别通过verilog与python打印压缩后序列,进行文本比对。

python代码

import sys
import random
import argparse
str_line = ''
def huffmancode(RG_type:int):
    if RG_type ==0b0000:
        return  '000',	'001',	'01',	'1',
    elif RG_type ==0b0001:
        return	'000',	'01',   '001',	'1'
    elif RG_type ==0b0010:
        return	'001',	'000',	'01',	'1'
    elif RG_type ==0b0011:
        return	'001',	'01',	'000',	'1'
    elif RG_type ==0b0100:
        return	'01',	'000',	'001',	'1'
    elif RG_type ==0b0101:
        return	'01',	'001',	'000',	'1'
    elif RG_type ==0b0110:
        return	'1',	'000',	'001',	'01'
    elif RG_type ==0b0111:
        return	'1',	'000',	'01',	'001'
    elif RG_type ==0b1000:
        return	'1',	'001',	'000',	'01'
    elif RG_type ==0b1001:
        return	'1',	'001',	'01',	'000'
    elif RG_type ==0b1010:
        return	'1',	'01',	'000',	'001'
    elif RG_type ==0b1011:
        return	'1',	'01',	'001',	'000'
    else:
        return  '000',	'001',	'01',	'1'
def get_data(file_name:str,unit_num=64,MAX_ITER=1000):
    f = open(file_name)
    lines = []
    number = unit_num*MAX_ITER
    count = 0
    while  True:
        line  =  f.readline()
        if count == number:
            break
        lines.append(line.strip())
        count = count+1
    f.close()
    return lines
def reshape(lines,unit_num=64,MAX_ITER=1000):
    units=[]
    for i in range(unit_num):
        tmp = ""
        for j in range(MAX_ITER):
            tmp =tmp+lines[i+unit_num*j] 
        units.append(tmp)
    return units
def get_d(data_line:str):
    assert len(data_line)%2==0,"length of input line isn't even"
    d_code=[]
    d_valid_code=[]
    new_flag =['1']
    for i in range(len(data_line)//2-1):
        flag = '1' if data_line[i*2:i*2+2]!=data_line[i*2+2:i*2+4] else '0'
        new_flag.append(flag)
    new_flag.append('0')
    new_flag.append('0')
    new_flag.append('0')
    d_code.append(data_line[0])
    d_code.append(data_line[1])
    d_valid_code.append('1')
    d_valid_code.append('1')
    index = 0
    while index * 2  < len(data_line):  
        cur_data = data_line[index*2:index*2+2]
        if new_flag[index+1]=='1':
            step = 1
        elif new_flag[index+1]=='0' \
            and new_flag[index+2]=='1':
            step = 2
        elif new_flag[index+1]=='0' \
            and new_flag[index+2]=='0':
            step = 3
        step = step if index + step < len(data_line)//2 else len(data_line)//2 -index
        code = 0
        if index+ step < len(data_line)//2:
            next_data = data_line[(index+step)*2:(index+step+1)*2]
            if cur_data == '11':
                code = '1' if next_data[0]=='1' or next_data[1]=='1' else '0'
            elif cur_data =='00':
                code = '1' if next_data[0]=='0' and next_data[1]=='1' else '0'
            elif cur_data =='01':
                code = '0' if next_data[0]=='1' or next_data[1]=='1' else '1'
            else :
                raise ValueError("10 occurs in dataline")
        if new_flag[index+step]=='1':
            d_code.append(code)
            d_valid_code.append(new_flag[index+step])
        index = index+ step
    return d_code
def get_l(data_line:str,huffmancode:tuple = ('000','001','01','1')):
    assert len(data_line)%2==0,"length of input line isn't even"
    code_0 = huffmancode[0]
    code_1 = huffmancode[1]
    code_2 = huffmancode[2]
    code_3 = huffmancode[3]
    l_code=[]
    new_flag =['1']
    for i in range(len(data_line)//2-1):
        flag = '1' if data_line[i*2:i*2+2]!=data_line[i*2+2:i*2+4] else '0'
        new_flag.append(flag)
    new_flag.append('0')
    new_flag.append('0')
    new_flag.append('0')
    index = 0
    next_code=''
    while index * 2  < len(data_line):  
        if new_flag[index+1]=='1':
            next_code = code_1
            step = 1
        elif new_flag[index+1]=='0' \
            and new_flag[index+2]=='1':
            next_code = code_2
            step = 2
        elif new_flag[index+1]=='0' \
            and new_flag[index+2]=='0'\
                and new_flag[index+3]=='1':
            next_code = code_3 + code_0
            step = 3
        elif new_flag[index+1]=='0' \
            and new_flag[index+2]=='0'\
                and new_flag[index+3]=='0':
            next_code = code_3
            step = 3
        if index + step >= len(data_line)//2 :
            step = len(data_line)//2 -index
            if step ==  1:
                next_code = code_1
            elif step == 2:
                next_code = code_2
            #elif step == 3:
            #    next_code, next_strb = 0b1000, 0b1111
        for i in range(len(next_code)): 
            l_code.append(next_code[i])
        index = index + step
    return l_code
def uncompress(d_code,l_code,huffmancode:tuple = ('000','001','01','1')):
    global str_line
    code_0 = huffmancode[0]
    code_1 = huffmancode[1]
    code_2 = huffmancode[2]
    code_3 = huffmancode[3]
    cur_data = d_code[0]+d_code[1]
    d_index = 2
    data_line = [cur_data]
    while d_index < len(d_code):
        next_data = ''
        if cur_data=='00':
            if d_code[d_index]=='0':
                next_data='11'
            if d_code[d_index]=='1':
                next_data='01'
        elif cur_data=='01':
            if d_code[d_index]=='0':
                next_data='11'
            if d_code[d_index]=='1':
                next_data='00'
        elif cur_data=='11':
            if d_code[d_index]=='0':
                next_data='00'
            if d_code[d_index]=='1':
                next_data='01'
        data_line.append(next_data)
        cur_data = next_data
        d_index = d_index + 1
    number_line=[]
    cur_num = 0
    cur_str = ''
    for i in range(len(l_code)):
        cur_str = cur_str + l_code[i]
        if cur_str == code_1:
            cur_num = cur_num + 1
            number_line.append(cur_num)
            cur_num = 0
            cur_str = ''
        elif cur_str == code_2:
            cur_num = cur_num + 2
            number_line.append(cur_num)
            cur_num = 0
            cur_str = ''
        elif cur_str == code_3:
            cur_num = cur_num + 3
            cur_str = ''
            if i == len(l_code)-1:
                number_line.append(cur_num)
                cur_num = 0
        elif cur_str == code_0:
            number_line.append(cur_num)
            cur_num = 0
            cur_str = ''
    assert len(data_line)==len(number_line),'during the test of {},the length of data and number are different'.format(str_line)
    uncompress_line =''
    for i in range(len(data_line)):
        for j in range(int(number_line[i])):
            uncompress_line = uncompress_line + data_line[i]
    return uncompress_line
def random_test_str(length:int):
    str_line = ''
    for i in range(length):
        a = random.randint(1,3)
        if a==1:
            str_line = str_line + '00'
        elif a==2:
            str_line = str_line + '01'
        elif a==3:
            str_line = str_line + '11'
    return str_line
def test(huffmancode:tuple = ('000','001','01','1')):
    global str_line 
    str_line = random_test_str(100)
    d_code=get_d(str_line)
    l_code=get_l(str_line,huffmancode)
    str_line1 = uncompress(d_code,l_code,huffmancode)
    assert str_line==str_line1, 'error occurs during the test of {}'.format(str_line)
def test_case(line):
    global str_line 
    str_line = line
    d_code=get_d(str_line)
    l_code=get_l(str_line)
    str_line1 = uncompress(d_code,l_code)
    assert str_line==str_line1, 'error occurs during the test of {}'.format(str_line)
def main(args):
    if args.generate_txt ==1:
        f = open('test_txt/test_win.txt','w')
        for i in range(args.units*args.max_iters):
            print(random_test_str(8),file=f)
        f.close()
        f = open('test_txt/test_grad.txt','w')
        for i in range(args.units*args.max_iters):
            print(random_test_str(160),file=f)
        f.close()
    else:
        if args.win_grad:
            line = reshape(get_data('test_txt/test_win.txt',args.units,args.max_iters),args.units,args.max_iters)[0]
        else:
            line = reshape(get_data('test_txt/test_grad.txt',args.units,args.max_iters),args.units,args.max_iters)[0]
        d_line = get_d(line)
        l_line = get_l(line,huffmancode(args.rg_type))
        f = open('test_txt/d_py_out.txt','w')
        for i in range(len(d_line)):
            print(d_line[i],file=f)
        f.close()
        f = open('test_txt/l_py_out.txt','w')
        for i in range(len(l_line)):
            print(l_line[i],file=f)
        f.close()
if __name__ == "__main__":
    parser = argparse.ArgumentParser()
    parser.add_argument('--generate-txt', type=int, default=0,help='1 for generate-txt, 0 for read txt and output d and l line txt')
    parser.add_argument('--units', type=int, default=64,help='num of units')
    parser.add_argument('--max-iters', type=int, default=1000,help='num of iters')
    parser.add_argument('--win-grad', type=int, default=1,help='1 for win, 0 for grad')
    parser.add_argument('--rg-type', type=int, default=0,help='RG_type')
    args = parser.parse_args()
    main(args)

shell脚本

#!/bin/bash
DESIGN_NAME="Compress_tb"
LOG_VCS="vcs.log"
LOG_SIMV="simv.log"
FILE_LIST="./list.f"
# Code Coverage
CM="-cm line+cond+tgl+fsm+branch+assert"
CM_DIR="-cm_dir cvrg"
rm -rf simv ucli.key novas.* *.log
rm -rf csrc simv.daidir verdiLog cvrg.vdb vdCovLog
rm -rf *_Golden*.txt *_DUT.txt
mkdir -p test_txt
for ((j=0;j<=10;j++))
do
	python3 compress.py --generate-txt 1        #python产生测试文本
	vcs -nc -j32 -full64 -sverilog -debug_access+all \
			+nospecify +notimingcheck +delay_mode_zero \
			-l ${LOG_VCS} -f ${FILE_LIST} ${CM} ${CM_DIR} #vcs仿真
	for ((z=0;z<=1;z++))
	do
		for ((i=0;i<=11;i++))
		do
			./simv -nc +COMPARE +fsdb+parallel \
				   -l ${LOG_SIMV} ${CM} ${CM_DIR} +RG_type=$i +win_grad=$z
			python3 compress.py --win-grad $z --rg-type $i
			if [ $(diff ./test_txt/l_py_out.txt ./test_txt/l_verilog_out.txt | wc -l) != 0 ];
				then echo "error exists in l line when rg_type=$i, win_grad=$z";exit 1;
			fi
			if [ $(diff ./test_txt/d_py_out.txt ./test_txt/d_verilog_out.txt | wc -l) != 0 ];
				then echo "error exists in d line when rg_type=$i, win_grad=$z";exit 1;
			fi
		done										
	done
done
echo "test success"

标签:index,code,str,compress,功能测试,模块,line,data,cur
From: https://www.cnblogs.com/xzh-personal-issue/p/17836229.html

相关文章

  • 首先加载核心模块,不管有没有同名/同目录的情况下,核心模块优先加载.
    在文件/home/somebody/workspace/somemodule.js中第一行引用了一个模块:require(‘othermodule‘),请问require查找模块的顺序是:A./home/somebody/workspace/node_modules/othermodule/index.jsB./home/somebody/workspace/node_modules/othermodule.JsC.COREMODULESnamedo......
  • nginx安装ssl模块
    一、引言当我们的Linux服务器上当中发布了web项目,有时候需要配置一个SSL证书,来使用https,然而我们一开始编译的Nginx的时候并没有把SSL模块一起编译进去.二、如何补装SSL模块既然在安装的时候没有编译ssl,难道把nginx卸载重新安装一次?不不不,我们只需要在原有的基础上添加ssl模块......
  • numpy模块
    一、numpy简介numpy官方文档:https://docs.scipy.org/doc/numpy/reference/?v=20190307135750numpy是Python的一种开源的数值计算扩展库。这种库可用来存储和处理大型numpy数组,比Python自身的嵌套列表结构要高效的多(该结构也可以用来表示numpy数组)。numpy库有两个作用:区别于li......
  • mac上python安装mysqlclient模块方法
    运行pycharm后,打开命令行窗口确保您已经安装了MySQL,并且包括了MySQL的开发文件。您可以通过Homebrew来安装MySQL:brewinstallmysql#安装mysqlclient之前,先安装openssl:brewinstallopenssl#使用以下命令来安装mysqlclient:envLDFLAGS="-I/usr/local/opt/openssl/i......
  • day14 模块和内置模块
    day14模块课程目标:掌握Python中常用模块的使用方法。今日概要:自定义模块(包)第三方模块内置模块【1/2】1.自定义模块1.1模块和包importhashlibdefencrypt(data):"""数据加密"""hash_object=hashlib.md5()hash_object.update(data.encode('utf......
  • 建简单的静态文件服务器:使用Node.js和HTTP模块
    创建简单的静态文件服务器:使用Node.js和HTTP模块在Web开发中,经常需要搭建一个能够提供静态文件访问的服务器。无论是用于本地开发调试,还是用于部署网站,这都是一个常见的需求。本篇文章将介绍如何使用Node.js和其内置的HTTP模块来创建一个简单的静态文件服务器。准备工作首先,确......
  • nginx-rust 基于rust 开发nginx 模块
    nginx-rust是nginx官方出的可以让我们基于rust开发nginx模块,目前还处于早期阶段,对于nginx类型的生成官方基于了bindgen工具这个工具我以前也简单介绍过,定于header包装如下图 说明目前来说官方提供的集成还是比较全的,同时对于标准nginx模块开发需要的数据类型也提供了......
  • 实验八. urllib模块、requests模块+BeautifulSoup模块使用、Feapder框架
    一、实验目标:熟悉模块的的用法,练习编写爬虫二、实验要求:编写代码,完成功能三、实验内容:(1)使用urllib模块或request模块读取网页内容,并利用BeautifulSoup模块进行内容解析,编写爬虫从http://www.cae.cn/cae/html/main/col48/column_48_1.html爬取中国工程院院士信息模......
  • 国标GB28181安防视频LiteCVR平台GIS电子地图模块开发介绍
    电子地图应用主要以GIS地理信息系统为核心,在联网监控工程视频监控业务管理中具有重要意义,能发挥GIS系统“一张图”可视化集成展示和空间决策分析方面的优势。视频监控平台LiteCVR可拓展性强、视频能力灵活、部署轻快,可支持的主流标准协议有国标GB28181、RTSP/Onvif、RTMP等,以及......
  • 如何根据不同仪器选择适合的电源模块?
    BOSHIDA如何根据不同仪器选择适合的电源模块?在实验室、工业生产等场合中,电源模块是必不可少的设备之一。电源模块的作用是将输入电能转换成所需要的电压和电流,为各种仪器设备提供恰当的电源。不同的仪器设备对电源的要求不同,因此在选择电源模块时需要根据具体的情况进行选择。下......