日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

离散余弦变换和C语言实现-win32版本

發(fā)布時(shí)間:2025/4/14 编程问答 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 离散余弦变换和C语言实现-win32版本 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

離散余弦變換,DCT for Discrete Cosine Transform。
是與傅里葉變換相關(guān)的一種變換,它類似于離散傅里葉變換(DFT for Discrete Fourier Transform),但是只使用實(shí)數(shù)。
離散余弦變換相當(dāng)于一個(gè)長度大概是它兩倍的離散傅里葉變換,這個(gè)離散傅里葉變換是對(duì)一個(gè)實(shí)偶函數(shù)進(jìn)行的(因?yàn)橐粋€(gè)實(shí)偶函數(shù)的傅里葉變換仍然是一個(gè)實(shí)偶函數(shù)),在有些變形里面需要將輸入或者輸出的位置移動(dòng)半個(gè)單位(DCT有8種標(biāo)準(zhǔn)類型,其中4種是常見的)。

離散余弦變換DCT具有信號(hào)譜分量豐富、能量集中,且不需要對(duì)語音相位進(jìn)行估算等優(yōu)點(diǎn),能在較低的運(yùn)算復(fù)雜度下取得較好的語音增強(qiáng)效果。

離散余弦變換,尤其是它的第二種類型,經(jīng)常被信號(hào)處理和圖像處理使用,用于對(duì)信號(hào)和圖像(包括靜止圖像和運(yùn)動(dòng)圖像)進(jìn)行有損數(shù)據(jù)壓縮。這是由于離散余弦變換具有很強(qiáng)的"能量集中"特性:大多數(shù)的自然信號(hào)(包括聲音和圖像)的能量都集中在離散余弦變換后的低頻部分;

在mpeg協(xié)議或jpeg格式的編碼中包含離散余弦變換,記不太清,可以自己查;

下面來看C語言實(shí)現(xiàn);

#include <windows.h> #include <math.h> #include "resource.h"LRESULT CALLBACK WindowProcedure (HWND, UINT, WPARAM, LPARAM);HINSTANCE hInst; TCHAR szClassName[] = TEXT("dctDemo"); #define PI 3.141593 #define N 4void dct(int x[4], HDC ); int WINAPI WinMain (HINSTANCE hThisInstance,HINSTANCE hPrevInstance,LPSTR lpszArgument,int nFunsterStil) {HWND hwnd;MSG messages;WNDCLASSEX wincl;hInst = hThisInstance;wincl.hInstance = hThisInstance;wincl.lpszClassName = szClassName;wincl.lpfnWndProc = WindowProcedure;wincl.style = CS_DBLCLKS;wincl.cbSize = sizeof (WNDCLASSEX);wincl.hIcon = LoadIcon (NULL, IDI_APPLICATION);wincl.hIconSm = LoadIcon (NULL, IDI_APPLICATION);wincl.hCursor = LoadCursor (NULL, IDC_ARROW);wincl.lpszMenuName = MAKEINTRESOURCE (IDC_DCTDEMO);wincl.cbClsExtra = 0;wincl.cbWndExtra = 0;wincl.hbrBackground = (HBRUSH)(COLOR_WINDOW+1);if (!RegisterClassEx (&wincl))return 0;hwnd = CreateWindowEx (0,szClassName,TEXT("離散余弦變換 Demo"),WS_OVERLAPPEDWINDOW,CW_USEDEFAULT,CW_USEDEFAULT,300,300,HWND_DESKTOP,NULL,hThisInstance,NULL);ShowWindow (hwnd, nFunsterStil);while (GetMessage (&messages, NULL, 0, 0)){TranslateMessage(&messages);DispatchMessage(&messages);}return messages.wParam; }LRESULT CALLBACK WindowProcedure (HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam) {PAINTSTRUCT ps;HDC hdc;RECT rt; char szBuffer[100]; int x1[] = {2,3,3,2};switch (message){case WM_COMMAND:switch (LOWORD(wParam)){case IDM_dct: hdc=GetDC(hwnd);dct(x1,hdc);break;case IDM_ABOUT:MessageBox (hwnd, TEXT ("dctDemo v1.0\nCopyright (C) 2020\n by bo"),TEXT ("離散余弦變換Demo"), MB_OK | MB_ICONINFORMATION);break;case IDM_EXIT:DestroyWindow(hwnd);break;default:return DefWindowProc(hwnd, message, wParam, lParam); }break;case WM_CREATE:break;case WM_PAINT:hdc = BeginPaint(hwnd, &ps); GetClientRect(hwnd, &rt); EndPaint(hwnd, &ps);break;case WM_DESTROY:PostQuitMessage (0);break;default:return DefWindowProc (hwnd, message, wParam, lParam);}return 0; }void dct(int x[4], HDC hdc) {int row=0;char szBuffer[20];int k,n;double A,s,X[4];for(k = 0; k < N; k++){s = 0;if(k==0)A = sqrt(1.0/N); //計(jì)算k=0時(shí)的系數(shù)elseA = sqrt(2.0/N); //計(jì)算k!=0時(shí)的系數(shù)for(n = 0; n < N; n++){double tmp = x[n]*cos((PI*(2*n+1)*k)/(2*N));s = s + tmp; //累加求和}X[k] = A * s; //X[k]等于累和結(jié)果s乘以系數(shù)A}for(k = 0; k < N; k++) {sprintf(szBuffer,"%.7lf",X[k]);TextOut(hdc,10,10+row*25,szBuffer,lstrlen(szBuffer));row=row+1;}}

這是計(jì)算4個(gè)點(diǎn)的DCT;要計(jì)算的值序列作為數(shù)組傳給DCT函數(shù);然后輸出;

控制臺(tái)的版本輸出如下;?

控制臺(tái)版本代碼;

?

#include<stdio.h> #include<math.h> #define PI 3.141593 #define N 4 int main() {int k, n;int x[] = {2,3,3,2};double A, s, X[4];for(k = 0; k < N; k++){s = 0;if(k==0)A = sqrt(1.0/N); //計(jì)算k=0時(shí)的系數(shù)elseA = sqrt(2.0/N); //計(jì)算k!=0時(shí)的系數(shù)for(n = 0; n < N; n++){double tmp = x[n]*cos((PI*(2*n+1)*k)/(2*N));s = s + tmp; //累加求和}X[k] = A * s; //X[k]等于累和結(jié)果s乘以系數(shù)A}for(k = 0; k < N; k++) printf("%f\n", X[k]); }

輸出的時(shí)候如果小數(shù)點(diǎn)格式化不對(duì)就會(huì)出現(xiàn)問題;正確的應(yīng)該是,

sprintf(szBuffer,"%.6lf",X[k]);?

工程;?

資源和頭文件;

#include "resource.h" #include <windows.h>/ // // Menu //IDC_DCTDEMO MENU BEGINPOPUP "&File"BEGINMENUITEM "離散余弦變換Demo", IDM_dctMENUITEM "E&xit", IDM_EXITENDPOPUP "&Help"BEGINMENUITEM "&About ...", IDM_ABOUTEND END #define IDM_EXIT 10001 #define IDM_ABOUT 10002#define IDC_DCTDEMO 10101 #define IDD_ABOUTBOX 10102 #define IDM_dct 40001

?

《新程序員》:云原生和全面數(shù)字化實(shí)踐50位技術(shù)專家共同創(chuàng)作,文字、視頻、音頻交互閱讀

總結(jié)

以上是生活随笔為你收集整理的离散余弦变换和C语言实现-win32版本的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 91青青视频| 你懂的国产视频 | 青青草av| aaa在线视频| 色噜噜成人 | 噜噜噜精品欧美成人 | 亚洲最大中文字幕 | 国内性爱视频 | 日韩成人免费在线 | 国产视频欧美视频 | 精品国产一区二区三 | 国产永久免费无遮挡 | 久久乐视频 | 日本va在线观看 | 播播成人网 | 国产伦精品一区二区三区网站 | 91精品国产麻豆 | 少妇一级淫免费观看 | 99精品视频网站 | 二级毛片视频 | 久久久免费 | 黄色三级视频在线观看 | www.haoav| 国产成人亚洲欧洲在线 | 成人精品一区二区三区四区 | 亚洲综合自拍 | 蜜臀av性久久久久蜜臀aⅴ流畅 | 毛片无码免费无码播放 | 综合人人| 在线亚洲网站 | 色偷偷资源 | 一区二区三区欧美 | 欧美黄色录像 | 成人a网站 | 野花av| 美女视频在线观看免费 | 福利视频一区二区 | 黄色a级片网站 | 成年视频在线观看 | 日韩欧美精品中文字幕 | 夜夜天堂| 欧美人妻日韩精品 | 天天操天天操天天操天天 | 台湾av在线 | yy4138理论片动漫理论片 | 亚洲一卡二卡在线观看 | 国产日产欧美一区二区三区 | 黑白配av | 天天色天天射综合网 | 欧美国产在线一区 | 不卡日本视频 | 高清视频在线免费观看 | 成人欧美精品 | 久久精品免费av | 天天色亚洲 | 91在线视频免费 | 四虎影视免费 | 国产在线一区二区三区四区 | 欧美伦理片 | 靠逼网站在线观看 | 免费看的av网站 | 亚洲欧美bt| 色宗合 | 欧美一区二区三区在线播放 | 国产一级做a爰片在线看免费 | www.在线观看视频 | 五月婷婷在线观看视频 | 国产伦理一区二区 | 打屁股视频网站 | 国产精品美女久久久久久久 | 国产高清久久久 | 久草精品在线观看视频 | 日本一区二区免费看 | 国产网站在线免费观看 | 日韩中文字幕一区 | 国产三级网站 | 国产午夜一级 | 免费一级做a爰片久久毛片潮 | 久久久久久久香蕉 | 天天操操| 中文字幕日本人妻久久久免费 | 精品国产乱码久久久久久久 | 狠狠干干干 | 亚洲制服一区二区 | 美女插插视频 | 国产一区二区三区视频播放 | 精产国品一二三产品蜜桃 | 非洲黑人毛片 | 国产在线不卡 | 伊人青青 | 成人淫片| 男人和女人做爽爽视频 | 人妻丰满熟妇av无码区免 | 日本亚洲国产 | 91视频二区 | 久久午夜夜伦鲁鲁片 | 久久小草| 性色tv | 青青草综合网 |