現在この質問をフォロー中です
- フォローしているコンテンツ フィードに更新が表示されます。
- コミュニケーション基本設定に応じて電子メールを受け取ることができます。
Hi !! I have a tiff image, which i have altered to get another matrix say a .Now, I want to compress and decompress it.
1 回表示 (過去 30 日間)
古いコメントを表示
nayana
2013 年 1 月 5 日
i want to compress my matrix(large size) a by using Huffman coding and then decode it again to get the original matrix a. can u post links of any coding u might know that solves my problem
14 件のコメント
nayana
2013 年 1 月 6 日
I have tried the file in this link http://www.mathworks.in/matlabcentral/fileexchange/19870-adaptive-huffman-coding
I got the result but my encoded output is uint8 class and of 110458233 bytes where as my original image is 839640 bytes and of uint16 type, so my question is did it really get compressed as the bytes are more in encoded image than in original
Walter Roberson
2013 年 1 月 6 日
The output stores only 1 bit per array element; the input had 16 bits per array element. You should be able to calculate from there.
nayana
2013 年 1 月 7 日
編集済み: nayana
2013 年 1 月 7 日
@walter Roberson, Thanks a lot for your help.Actually i am new to mat lab. so i could not figure this out... As you said the output stores less bits per each array element but on whole total no of bits of output is more than total bits of input.so can u clarify whether its compressed or not pls!!
nayana
2013 年 1 月 7 日
編集済み: Walter Roberson
2013 年 1 月 7 日
@ walter Roberson
i have used code in this link http://www.mathworks.in/matlabcentral/fileexchange/19870-adaptive-huffman-coding and even other codes but whatever i try output size is more than input.
can u please suggest me some coding to compress an array, where i am storing all the coordinate values and intensity values of an image in that array.
Walter Roberson
2013 年 1 月 7 日
Why are you storing all the coordinate values? Is your image not defined over a regular grid? Why not at most store the first coordinate and the last coordinate for each of the two dimensions, if the coordinates are equally spaced?
nayana
2013 年 1 月 8 日
編集済み: nayana
2013 年 1 月 8 日
I need to compress such array, that's the job my professor gave to me.anyway i just want output size to be decreased,if 5 elements are there i want it to take it as 5 bits ,but since its of type uint8 its taking 1 byte. i want to convert it into a suitable format so that it will take only 1 bit or something less than 1 byte... By storing the output it in a text file or any other file or by changing its format, if its possible to reduce size, can u please suggest me
Walter Roberson
2013 年 1 月 8 日
fwrite() each of the uint8 that encodes a bit; use 'ubit1' precision.
nayana
2013 年 1 月 9 日
Thank you.Its working but after storing output into file when i try to read it, the size of the result is one less than that of input.. Do u have an idea about this???
Walter Roberson
2013 年 1 月 9 日
Make sure you write a multiple of 8 bits, as files can only store multiples of 8 bits.
回答 (1 件)
Jan
2013 年 1 月 5 日
参考
カテゴリ
Help Center および File Exchange で Import, Export, and Conversion についてさらに検索
タグ
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!エラーが発生しました
ページに変更が加えられたため、アクションを完了できません。ページを再度読み込み、更新された状態を確認してください。
Web サイトの選択
Web サイトを選択すると、翻訳されたコンテンツにアクセスし、地域のイベントやサービスを確認できます。現在の位置情報に基づき、次のサイトの選択を推奨します:
また、以下のリストから Web サイトを選択することもできます。
最適なサイトパフォーマンスの取得方法
中国のサイト (中国語または英語) を選択することで、最適なサイトパフォーマンスが得られます。その他の国の MathWorks のサイトは、お客様の地域からのアクセスが最適化されていません。
南北アメリカ
- América Latina (Español)
- Canada (English)
- United States (English)
ヨーロッパ
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom(English)
アジア太平洋地域
- Australia (English)
- India (English)
- New Zealand (English)
- 中国
- 日本Japanese (日本語)
- 한국Korean (한국어)