Python科学计算——如何构建模型?

模式识别 (Pattern Recognition)是近年来比较流行的字眼,通俗地讲,就是通过计算机用数学技术方法来研究模式的自动处理和判读,而模式环境客体的总称。模式识别过程中,关键的一步是特征提取,即抽取一组特征,将输入模式从对象空间映射到特征空间,这样,模式就可以用特征空间中的一个点或一个特征矢量表示。模型的构建过程和模式识别有相似的地方,即通过一个特征矢量唯一确定一个模式。在构建模型的过程中就存在这样一个问题:应该用几个维度的特征矢量去唯一表征一个模型?在本文中,以三角波为例,探究几个维度的特征矢量能够唯一表征三角波模型。

基础准备

一维特征矢量

在我们的印象里,三角波只要知道频率周期就可以确定了,这便是标准的三角波。

def triangle_wave(x,p):
    T = p
    y = np.where(np.mod(x,T)<T/2, -4/T*(np.mod(x,T))+1, 0)
    y = np.where(np.mod(x,T)>=T/2, 4/T*(np.mod(x,T))-3, y)
    return y 
一维特征矢量: [0.2] 描述的三角波

二维特征矢量

很多时候,会发现,在横坐标为0时,并不对应最大值或最小值,而是对应某一个中间值,这个时候标准的三角波就不能表征这种情况,我们需要加入水平平移特征变量,修正后的模型如下:

def triangle_wave(x,p):
    b, T = p
    y = np.where(np.mod(x-b,T)<T/2, -4/T*(np.mod(x-b,T))+1, 0)
    y = np.where(np.mod(x-b,T)>=T/2, 4/T*(np.mod(x-b,T))-3, y)
    return y 
二维特征矢量: [0.08,0.2] 描述的三角波

三维特征矢量

有时,也存在这种情况,三角波的幅值并不总是等于1,因此我们需要加入纵向伸缩特征变量,修正后的模型如下:

def triangle_wave(x,p):
    a,b,T = p
    y = np.where(np.mod(x-b,T)<T/2, -4/T*(np.mod(x-b,T))+1, 0)
    y = np.where(np.mod(x-b,T)>=T/2, 4/T*(np.mod(x-b,T))-3, y)
    return a*y 
三维特征矢量: [0.5,0,0.2]描述的三角波

四维特征矢量

有时,还存在波形并不关于y轴对称的情况,针对这种情况,我们需要加入纵向平移特征变量,修正后的模型如下:

def triangle_wave(x,p):
    a,b,c,T = p
    y = np.where(np.mod(x-b,T)<T/2, -4/T*(np.mod(x-b,T))+1+c/a, 0)
    y = np.where(np.mod(x-b,T)>=T/2, 4/T*(np.mod(x-b,T))-3+c/a, y)
    return a*y
四维特征向量: [0.5,0.08,0.1,0.2] 描述的三角波

五维特征矢量

有时,还会发现三角波的三角波每个峰的高度并不完全相等,这是因为信号中存在噪声,这时,就需要加入噪声特征变量,这里我们以标准高斯白噪声为例,修正后的模型如下:

def triangle_wave(x,p):
    a,b,c,d,T = p
    y = np.where(np.mod(x-b,T)<T/2, -4/T*(np.mod(x-b,T))+1+c/a, 0)
    y = np.where(np.mod(x-b,T)>=T/2, 4/T*(np.mod(x-b,T))-3+c/a, y)
    return a*y+d*np.random.randn(len(x))

五维特征矢量: [0.5,0.08,0.1,0.015,0.2] 描述的三角波

注:周期 T 表征图形在横向伸缩特征,幅值 a 表征图形在纵向伸缩特征,时延 b 表征图像在横向平移特征,c 表征图形在纵向平移特征,噪声 d 为图形添加了随机性特征,同时也表征了幅值参差不齐的特征。(仅供参考)

Stay hungry, Stay foolish. -- Steve Jobs

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,378评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,356评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,702评论 0 342
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,259评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,263评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,036评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,349评论 3 400
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,979评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,469评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,938评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,059评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,703评论 4 323
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,257评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,262评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,485评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,501评论 2 354
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,792评论 2 345

推荐阅读更多精彩内容

  • 这些年计算机视觉识别和搜索这个领域非常热闹,后期出现了很多的创业公司,大公司也在这方面也花了很多力气在做。做视觉搜...
    方弟阅读 6,444评论 6 24
  • 五、Deep Learning的基本思想 假设我们有一个系统S,它有n层(S1,…Sn),它的输入是I,输出是O,...
    dma_master阅读 1,620评论 1 2
  • 不同图像灰度不同,边界处一般会有明显的边缘,利用此特征可以分割图像。需要说明的是:边缘和物体间的边界并不等同,边缘...
    大川无敌阅读 13,822评论 0 29
  • 从马云的一些语言,让我这个20岁的人开始用积极乐观的去想经济与人的交往。我觉得自己开始有对经济感兴趣,想去开始涉猎...
    杰科阅读 152评论 0 0
  • (5) 旅途中丢了一只袜子,其他一切正常。 我不满意崔健歌里面一句词,以至于每次在KTV我都要按照我的理解...
    Clytie李咸阅读 844评论 0 1