線上訂房服務-台灣趴趴狗聯合訂房中心
發文 回覆 瀏覽次數:1239
推到 Plurk!
推到 Facebook!

[BCB]用模糊理論求相似度

尚未結案
imjoshua
一般會員


發表:36
回覆:21
積分:11
註冊:2005-03-16

發送簡訊給我
#1 引用回覆 回覆 發表時間:2005-08-15 16:56:06 IP:220.139.xxx.xxx 未訂閱
各位前輩您好!!            小弟有一張256*256的image 假設圖片的投影量為Xi,因為是256*256的圖;所以i = 0~255 相似度為對應Xi的Pi 若(μ+σ)≦Xi≦(μ-σ) ,則Pi = 1 若(μ+σ)≦Xi≦(μ+1.64σ) ,則Pi =[(μ+1.64σ)- Xi] /0.64σ 若(μ-1.64σ)≦Xi≦(μ-σ) ,則Pi =[ Xi-(μ-1.64σ)] /0.64σ 若Xi≧(μ+1.64σ) ,則Pi =[(μ+1.64σ)- Xi] /0.64σ ,若Pi≦-1,則令Pi=1 若Xi≦(μ-1.64σ) ,則Pi =[ Xi-(μ-1.64σ)] /0.64σ,若Pi≦-1,則令Pi=1 當求得每一橫做標的相似度Pi值後,相似度平均值 = P = (P0+P1........+P256)/256, 若P<0 , 則令P = 0 以上是用模糊理論之梯型函數得知 投影量及μ、σ小弟已得到答案! 如下圖: 是否要用if 、else做出?大概要如何去做它呢? 如何用梯型函數做出相似度呢?拜託大大給予小弟提示或方向 打擾您保貴的閱讀時間在此跟您說聲抱歉!! 發表人 - imjoshua 於 2005/08/15 17:10:30
------
joshua
imjoshua
一般會員


發表:36
回覆:21
積分:11
註冊:2005-03-16

發送簡訊給我
#2 引用回覆 回覆 發表時間:2005-08-16 01:54:23 IP:220.139.xxx.xxx 未訂閱
http://delphi.ktop.com.tw/topic.php?TOPIC_ID=76842 相關作品在上方連結;請大大參考謝謝 打擾您保貴的閱讀時間在此跟您說聲抱歉!!
------
joshua
imjoshua
一般會員


發表:36
回覆:21
積分:11
註冊:2005-03-16

發送簡訊給我
#3 引用回覆 回覆 發表時間:2005-08-24 16:58:41 IP:61.228.xxx.xxx 未訂閱
極新手的我目前只知道把m、div再做成陣列如    int m[256] = {0};  //平均值 float div[256] = {0};  //標準差    for(int i = 0; i < 256; i++) m[i] = ( a[i] + b[i] +c[i] +d[i] +e[i] +f[i])/6 ;    for(int i = 0; i < 256; i++) { div[i] = pow((a[i] - m[i]), 2) + pow((b[i] - m[i]), 2) + pow((c[i] - m[i]), 2) + pow((d[i] - m[i]), 2) + pow((e[i] - m[i]), 2) + pow((f[i] - m[i]), 2); div[i] = sqrt(div[i] / 6.0);                                 } //接著要跟一張全新的image7做比較               // 統計水平與垂直方向的投影量 long ProjectV[256] = {0}; long ProjectH[256] = {0}; long Vmax = 0, Hmax = 0; Byte *ptr;     for(int row = 0; row < 256; row++) { ptr = (Byte *)Image7->Picture->Bitmap->ScanLine[row]; for(int col = 0; col < 256; col++) { if(ptr[col*3] == 0) // 黑色部份       {          ProjectV[col]++; // 垂直方向投影的數量+1          ProjectH[row]++; // 水平方向投影的數量+1          if(ProjectV[col] > Vmax) Vmax = ProjectV[col]; // 統計垂直投影最大值          if(ProjectH[row] > Hmax) Hmax = ProjectH[row]; // 統計水平投影最大值        }     }   } 最後就是套用模糊理論的算式了…但是出來時有點給他怪怪的@@如果要用if else寫的話大概要如何寫呢?    for(int col = 0 ; col<256 ; col ) { if (((m[col] div[col])>= ProjectM[col]) && ((m[col]-div[col])<= ProjectM[col])) p = 1 ; if (((m[col] div[col])<=ProjectM[col]) && ((m[col] 1.64*div[col])>=ProjectM[col])) p = ((m[col] 1.64*div[col])-ProjectV[col])/0.64*div[col]; else p = 0; if (((m[col]-1.64*div[col])<=ProjectM[col]) && ((m[col]-div[col])>=ProjectM[col])) p = (ProjectM[col]-(m[col]-1.64*div[col]))/0.64*div[col]; else p =0; if ((m[col] 1.64*div[col])<=ProjectM[col]) p = ((m[col] 1.64*div[col])-ProjectM[col])/0.64*div[col]; if(p<=-1) p= -1; if ((m[col]-1.64*div[col])>=ProjectM[col]) p = (ProjectM[col]-(m[col]-1.64*div[col]))/0.64*div[col]; if(p<=-1) p = -1; } 以上的if else是我亂寫的請問要如何改…請前輩救救我這個呆呆不會寫程式男~(淚) ================================== 或是先把字串變成變數宣告(會不會多此一舉?) 以下是模糊理論條件1、條件2 for(int col = 0 ; col<256 ; col ) { float mm = 0; float fdiv = 0; int V = 0; mm = m[col]; fdiv = div[col]; V = ProjectV[col]; if (((mm fdiv)>= V) && ((mm-fdiv)<= V)) p = 1 ; else if(p<=0) p = 0; else if (((mm fdiv)<=V) && ((mm 1.64*fdiv)>= V)) p = 1; else p = 0; j =p; p = j / 256; } Edit1->Text = p; 打擾您保貴的閱讀時間在此跟您說聲抱歉!! 發表人 - imjoshua 於 2005/08/24 17:07:25
------
joshua
系統時間:2024-05-05 2:04:37
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!