上機(jī)題之22
以下內(nèi)容為程序代碼:
;* 請(qǐng)編制程序PROG1.ASM, 其功能是: 內(nèi)存中從SOURCE開(kāi)始連續(xù)
;* 存放著二十一個(gè)八位有符號(hào)數(shù)(補(bǔ)碼),其相鄰兩數(shù)之間差值不超過(guò)
;* -8至7。對(duì)這種變化緩慢的數(shù)據(jù)可采用差分方法進(jìn)行壓縮。即第一
;* 個(gè)數(shù)據(jù)不變,其后的數(shù)據(jù)取與前一數(shù)據(jù)的差值并用四位二進(jìn)制補(bǔ)碼
;* 表示, 兩個(gè)差值拼成一個(gè)字節(jié), 前一個(gè)差值放在高四位,后一個(gè)差
;* 值放在低四位。
;* 例如:
;* 原數(shù)據(jù)(X[n]): 23H,27H,2AH,29H,22H,...
;* 壓縮后(Y[n]): 23H, 43H, F9H,...
;* 編程按上述方法進(jìn)行壓縮, 結(jié)果保存在RESULT開(kāi)始的內(nèi)存單
;* 元中。
;* 部分程序已在PROG1.ASM中給出, 請(qǐng)?zhí)羁誃EGIN和END之間已給
;* 出的源程序使其完整(空白已用橫線標(biāo)出, 每行空白一般只需一條
;* 指令, 但功能相當(dāng)?shù)亩鄺l指令亦可)或刪除BEGIN和END之間原有的
;* 代碼并自行編寫程序片段來(lái)完成要求的功能。
;* 原始數(shù)據(jù)由過(guò)程LOAD從文件INPUT1.DAT中讀入SOURCE開(kāi)始的內(nèi)
;* 存單元中, 結(jié)果要求從RESULT開(kāi)始存放, 由過(guò)程SAVE保存到文件
;* OUTPUT1.DAT中。
;* 對(duì)程序必須進(jìn)行匯編, 并與IO.OBJ鏈接產(chǎn)生PROG1.EXE 執(zhí)行文
;* 件, 最終運(yùn)行程序產(chǎn)生結(jié)果(無(wú)結(jié)果或結(jié)果不正確者均不得分)。
EXTRN LOAD:FAR,SAVE:FAR
N EQU 10
STAC SEGMENT STACK
DB 128 DUP (?)
STAC ENDS
DATA SEGMENT
SOURCE DB 2*N+1 DUP(?)
RESULT DB N+1 DUP(0)
NAME0 DB ’INPUT1.DAT’,0
NAME1 DB ’OUTPUT1.DAT’,0
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE, DS:DATA, SS:STAC
START PROC FAR
PUSH DS
XOR AX,AX
PUSH AX
MOV AX,DATA
MOV DS,AX
MOV ES,AX ; 置附加段寄存器
LEA DX,SOURCE ; 數(shù)據(jù)區(qū)起始地址
LEA SI,NAME0 ; 原始數(shù)據(jù)文件名起始地址
MOV CX,2*N+1 ; 字節(jié)數(shù)
CALL LOAD ; 從"input1.dat"中讀取數(shù)據(jù); **** BEGIN ****
LEA SI,SOURCE
LEA DI,RESULT
CLD
MOVSB ; Y[0]=X[0]
XOR BX,BX ; FLAG=0
MOV DX,N*2 ; COUNTER
COMPRESS:
LODSB
sub al,[si-2]
xor bx,1
jz low_hex
;SUB _________ ; X[n]-X[n-1]
;____________________ ; FLAG=NOT FLAG
;J__ LOW_HEX
MOV CL,4
shl al,cl
;___ AL,CL
MOV AH,AL
JMP NEXT
LOW_HEX: and al,0fh
;__________________
OR AL,AH
STOSB
NEXT: dec dx
;___________________
JNE COMPRESS
; **** END ****
LEA DX,RESULT ; 結(jié)果數(shù)據(jù)區(qū)首址
LEA SI,NAME1 ; 結(jié)果文件名起始地址
MOV CX,N+1 ; 字節(jié)數(shù)
CALL SAVE ; 保存結(jié)果到"output1.dat"文件中
RET
START ENDP
CODE ENDS
END START
input1.dat 內(nèi)容如下:[b]
17 1B 1E 24 29 2D 2A 25 20 27 2C 2F 34 37 33 31 36 3C 3F 39 33
[b]output1.dat 內(nèi)容應(yīng)當(dāng)如下:
17 43 65 4D BB 75 35 3C E5 63 AA
以下內(nèi)容為程序代碼:
;* 請(qǐng)編制程序PROG1.ASM, 其功能是: 內(nèi)存中從SOURCE開(kāi)始連續(xù)
;* 存放著二十一個(gè)八位有符號(hào)數(shù)(補(bǔ)碼),其相鄰兩數(shù)之間差值不超過(guò)
;* -8至7。對(duì)這種變化緩慢的數(shù)據(jù)可采用差分方法進(jìn)行壓縮。即第一
;* 個(gè)數(shù)據(jù)不變,其后的數(shù)據(jù)取與前一數(shù)據(jù)的差值并用四位二進(jìn)制補(bǔ)碼
;* 表示, 兩個(gè)差值拼成一個(gè)字節(jié), 前一個(gè)差值放在高四位,后一個(gè)差
;* 值放在低四位。
;* 例如:
;* 原數(shù)據(jù)(X[n]): 23H,27H,2AH,29H,22H,...
;* 壓縮后(Y[n]): 23H, 43H, F9H,...
;* 編程按上述方法進(jìn)行壓縮, 結(jié)果保存在RESULT開(kāi)始的內(nèi)存單
;* 元中。
;* 部分程序已在PROG1.ASM中給出, 請(qǐng)?zhí)羁誃EGIN和END之間已給
;* 出的源程序使其完整(空白已用橫線標(biāo)出, 每行空白一般只需一條
;* 指令, 但功能相當(dāng)?shù)亩鄺l指令亦可)或刪除BEGIN和END之間原有的
;* 代碼并自行編寫程序片段來(lái)完成要求的功能。
;* 原始數(shù)據(jù)由過(guò)程LOAD從文件INPUT1.DAT中讀入SOURCE開(kāi)始的內(nèi)
;* 存單元中, 結(jié)果要求從RESULT開(kāi)始存放, 由過(guò)程SAVE保存到文件
;* OUTPUT1.DAT中。
;* 對(duì)程序必須進(jìn)行匯編, 并與IO.OBJ鏈接產(chǎn)生PROG1.EXE 執(zhí)行文
;* 件, 最終運(yùn)行程序產(chǎn)生結(jié)果(無(wú)結(jié)果或結(jié)果不正確者均不得分)。
EXTRN LOAD:FAR,SAVE:FAR
N EQU 10
STAC SEGMENT STACK
DB 128 DUP (?)
STAC ENDS
DATA SEGMENT
SOURCE DB 2*N+1 DUP(?)
RESULT DB N+1 DUP(0)
NAME0 DB ’INPUT1.DAT’,0
NAME1 DB ’OUTPUT1.DAT’,0
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE, DS:DATA, SS:STAC
START PROC FAR
PUSH DS
XOR AX,AX
PUSH AX
MOV AX,DATA
MOV DS,AX
MOV ES,AX ; 置附加段寄存器
LEA DX,SOURCE ; 數(shù)據(jù)區(qū)起始地址
LEA SI,NAME0 ; 原始數(shù)據(jù)文件名起始地址
MOV CX,2*N+1 ; 字節(jié)數(shù)
CALL LOAD ; 從"input1.dat"中讀取數(shù)據(jù); **** BEGIN ****
LEA SI,SOURCE
LEA DI,RESULT
CLD
MOVSB ; Y[0]=X[0]
XOR BX,BX ; FLAG=0
MOV DX,N*2 ; COUNTER
COMPRESS:
LODSB
sub al,[si-2]
xor bx,1
jz low_hex
;SUB _________ ; X[n]-X[n-1]
;____________________ ; FLAG=NOT FLAG
;J__ LOW_HEX
MOV CL,4
shl al,cl
;___ AL,CL
MOV AH,AL
JMP NEXT
LOW_HEX: and al,0fh
;__________________
OR AL,AH
STOSB
NEXT: dec dx
;___________________
JNE COMPRESS
; **** END ****
LEA DX,RESULT ; 結(jié)果數(shù)據(jù)區(qū)首址
LEA SI,NAME1 ; 結(jié)果文件名起始地址
MOV CX,N+1 ; 字節(jié)數(shù)
CALL SAVE ; 保存結(jié)果到"output1.dat"文件中
RET
START ENDP
CODE ENDS
END START
input1.dat 內(nèi)容如下:[b]
17 1B 1E 24 29 2D 2A 25 20 27 2C 2F 34 37 33 31 36 3C 3F 39 33
[b]output1.dat 內(nèi)容應(yīng)當(dāng)如下:
17 43 65 4D BB 75 35 3C E5 63 AA

