1. Trang chủ
  2. » Luận Văn - Báo Cáo

Tìm hiểu ngôn ngữ VC++6.0 Và ứng dụng trong việc giải nén tập tin văn bản

16 594 1
Tài liệu đã được kiểm tra trùng lặp

Đang tải... (xem toàn văn)

Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống

THÔNG TIN TÀI LIỆU

Thông tin cơ bản

Tiêu đề Tìm hiểu ngôn ngữ VC++ 6.0 và ứng dụng trong việc nén và giải nén tập tin văn bản
Tác giả Nguyễn Đức Nghĩa
Người hướng dẫn Th.s Huỳnh Thanh Bình
Trường học Nha Trang University
Thể loại Đồ án tốt nghiệp
Năm xuất bản 2003
Thành phố Nha Trang
Định dạng
Số trang 16
Dung lượng 113 KB

Các công cụ chuyển đổi và chỉnh sửa cho tài liệu này

Nội dung

Tìm hiểu ngôn ngữ VC++6.0 Và ứng dụng trong việc giải nén tập tin văn bản

Trang 1

§å ¸N TèT NGHIÖP

§Ò Tµi:

T×M HIÓU NG¤N NG÷ VC++ 6.0 Vµ øng dông

trong viÖc nÐn vµ gi¶i nÐn tËp tin v¨n b¶n

GVHD: Th.s Huúnh Thanh B×nh SVTH:NguyÔn §øc NghÜa

MSSV:98S1049 Líp 40TH

Trang 2

Lời Cảm Ơn

Em xin đ ợc nói lên lời cảm ơn đấng sinh thành và Thầy, Cô đã nuôi, dạy

em lớn khôn.

Trang 3

Yêu cầu của đề tài

Tìm hiểu ngôn ngữ VC ++ 6.0

Nghiên cứu và cài đặt một số thuật toán nén và giải nén tập tin văn bản

 Những khỏi niệm cơ bản và mục đớch của việc nộn dữ liệu.

 Một số phương phỏp nộn

 Thực hiện chương trỡnh

Trang 4

Những khái niệm cơ bản và mục

đích của việc nén dữ liệu

*Khỏi niệm dữ liệu

Là bao gồm cỏc phần tử cơ sở mà ta gọi là dữ liệu

nguyờn tử

*Mục đớch của việc nộn dữ liệu

Lưu trữ dữ liệu được nhiều hơn

Tiết kiệm được vựng nhớ

Giảm chi phớ lưu trữ

Mang lại hiệu quả cho việc truyền dữ liệu trờn mạng

*Dạng nộn

Trang 5

*Quá trình nén và giải nén

Công đoạn nén:

Dữ liệu Mã hoá Đóng gói Dữ liệu nén

Công đoạn giải nén:

Giải mã Mã hoá

Trang 6

MỘT SỐ PHƯƠNG PHÁP NÉN

*Định nghĩa nén dữ liệu

Là để ghi lại dòng dữ liệu sao cho tốn ít bộ nhớ hơn mà có thể cho phép chúng ta khôi phục lại dữ liệu ban đầu

*Một số loại mã

 Mã ký hiệu:Quy ước các mã được sử dụng để nhận ra một chuỗi các sự kiện khác nhau

Mã đóng gói:Trong phương pháp mã bao giờ cũng có một khâu đóng gói

Mã theo độ dài:Là phát hiện một ký tự có số lần xuất hiện liên tiếp vượt qua một ngưỡng cố định nào đó

Trang 7

*Mô hình nén

 Nén dữ liệu có mô hình nguồn

Những thuật toán nén dữ liệu đặt trưng cho mô hình nguồn điển hình là:

 Thuật toán Huffman

 Thuật toán Fano-Shannon

 Nén dữ liệu chưa có mô hình nguồn

Một trong những đặt điểm nén dữ liệu chưa có mô hình nguồn là ngôn ngữ tự nhiên

Trang 8

*Kỹ thuật từ điển

nhỏ hơn sao cho nó đạt được độ dài nhất có thể được mà nó

đã xuất hiện trong quá khứ

hơn, mỗi đoạn được gọi là một phân đoạn

khác là từ điển tĩnh

Được xây dựng trong quá trình chạy chương trình

Trang 9

THỰC HIỆN CHƯƠNG TRÌNH

*Chương trình đã cài đặt được các thuật toán nén theo kỹ thuật từ điển sau:

Thuật toán LZSS

 Thuật toán LZARI

Thuật toán LZW

Trang 10

* Thuật toán LZSS

Thuật toán nén:

1. Đặt vị trí mã hoá nơi bắt đầu của dòng đầu vào

2. Tìm sự phù hợp tối đa trong cửa sổ cho vùng đệm

P :=con trỏ tới sự phù hợp

L:= chiều dài của sự phù hợp

3 If L>=MIN_LENGTH then

-Đầu ra P và di chuyển vị trí mã hoá một ký tự ở trước else

Đầu ra là ký tự đầu tiên của vùng đệm và chuyển vị trí

mã hoá một ký tự ở trước

4.Nếu có nhiều ký tự trong luồng đầu vào thì trở về bước 2 Thuật toán giải nén:

Trang 11

Ví dụ thuật toán nén lzss

Trang 12

*Thuật toán LZW

Thuật toán nén lzw:

String=lấy ký tự vào

While vẫn còn ký tự vào Do

begin

ch:=lấy ký tự vào

if String +ch là trong bảng chuỗi then

String = String+ch

else

begin

Đầu ra Code của String

Thêm String + ch tới bảng chuỗi String String=ch

end;

End;

Trang 13

Thuật toán giải nén LZW

Read Old_code

While Vẫn còn ký tự đầu vào Do

begin

read New_code

String=sự chuyển đổi của New_code

Output String

ch= ch đầu tiên trong String

Thêm Old_code + ch để chuyển đổi bảng old_code=New_code

end

Trang 14

* Thuật toán LZW

Ví dụ thực hiện nén:

Ví dụ thực hiện giải nén:

Trang 15

*So sánh giữa các thuật toán

Trang 16

KẾT LUẬN

*Đánh giá chương trình

Đã cài đặt được một số thuật toán nén theo kỹ thuật từ điển như: LZSS, LZARI,LZW

Do hạn chế về tài liệu tham khảo nên một số thuật toán nén khác chưa cài đặt được

*Hướng phát triễn

Có thể mở rộng chương trình để thực hiện trong việc nén tập tin hình ảnh

Ngày đăng: 24/04/2013, 19:56

TỪ KHÓA LIÊN QUAN

TÀI LIỆU CÙNG NGƯỜI DÙNG

TÀI LIỆU LIÊN QUAN

🧩 Sản phẩm bạn có thể quan tâm

w