• 一个 周期信号 分解为 若干个 正弦信号


    一个 周期信号 分解为 若干个 正弦信号,   就是 傅里叶级数,  不过 我对 傅里叶级数 了解不多,  一方面 是 懒得去 细看, 一方面 也是 为了 保持 神秘感 。

     

    我们把  一个 周期信号, 甚至 非周期信号,   记为   y =   Src ( t )  ,  也称为  源信号  。

     

    傅里叶级数 的 一般形式 可以 写为 :         Sin [ 1 ] + Sin [ 2 ] + Sin [ 3 ] + …… + Sin [ n ]    ,     n -> 无穷

     

    Sin [ n ] =  An * sin ( ωn * t + ψn ) +  bn  ,         A 为 振幅,  ω 为 角速度,  t 为 时间,  ψ 为 初始相位,  b 为 增量,  n 为 项 的 序号(下标),   An 是 第 n 项 的 振幅,  ωn 是 第 n 项 的 角速度,  ψn 是 第 n 项 的 初始相位,  bn 是 第 n 项 的 增量  。

     

    那么,   将 y = Src ( t )    展开 为 傅里叶级数 可以 这样表示 :

     

    Src ( t ) =   Sin [ 1 ] + Sin [ 2 ] + Sin [ 3 ] + …… + Sin [ n ]         ,    n -> 无穷

     

    只要 确定了 每一项 的  A 、ω 、ψ 、b ,    就 得到 源信号 对应 的 傅里叶级数 了  。

     

    那么,   每一项 的  A 、ω 、ψ 、b  怎么 确定  ?

     

    记  Sins ( t )  =  Sin [ 1 ] + Sin [ 2 ] + Sin [ 3 ] + …… + Sin [ n ]   ,   n -> 无穷

    可以写一个  定积分,       ʃ  | Src (t) - Sins (t) |  dt  ,   [ t1, t2 ]   ,    

    [ t1, t2 ]  是 定积分 的 区间, 也是 源信号 的 区间,

     

     | Src (t) - Sins (t) |   表示  Src (t) - Sins (t)   的 绝对值   。

     

    我们 只要 找出 让     ʃ  | Src (t) - Sins (t) |  dt  ,   [ t1, t2 ]       这个 定积分 的 值 等于 0 的 条件 就可以了  。

    就是说,   我们要 为 每一项 找到 合适 的  A 、ω 、ψ 、b ,    使得      ʃ  | Src (t) - Sins (t) |  dt  ,   [ t1, t2 ]   =   0    。

    这是一个 泛函 问题  。

     

      ʃ  | Src (t) - Sins (t) |  dt  ,   [ t1, t2 ]       这个 定积分  的 意义是   Src (t)  和  Sins (t)   的 波形 的 差异 有多大,  若 这个 定积分 为 0, 则  Src (t)  和  Sins (t)  的 波形 完全相同   。

     

    因为  Sins (t)  是 无穷级数,  由 n 个 项 组成,  n -> 无穷,   所以,  

     

      ʃ  | Src (t) - Sins (t) |  dt  ,   [ t1, t2 ]   =   0       (1) 式

     

    也可以写为      ʃ  | Src (t) - Sins (t) |  dt  ,   [ t1, t2 ]   ->   0       (2) 式

     

    (1) 式 是 等于 0,   (2) 式 是 趋于 0    。

     

    (1) 式 和 (2) 式  是 一个 泛函方程,  也是 一个 积分方程 。

    (1) 式 (2) 式  的 解  是  每一项 的  A 、ω 、ψ 、b,   可以 写成 矩阵 :

     

    A1 , ω1 , ψ1 , b1

    A2 , ω2 , ψ2 , b2

    A3 , ω3 , ψ3 , b3

    ……

    An , ωn , ψn , bn

     

    Oh  ……   终于 知道 矩阵 有什么用了  ……

     

    一般的,  泛函 的 常见问题 是 求 最小积分条件,   所以,  (1) 式 (2) 式 还可以 写成 :

     

    ʃ  | Src (t) - Sins (t) |  dt  ,   [ t1, t2 ]   ->   min         (3) 式

     

    表示    ʃ  | Src (t) - Sins (t) |  dt  ,   [ t1, t2 ]        趋于 最小,

     

    (3) 式 和 (1) 式 (2) 式 的 意思 差不多  。       下面 我们 就以 (1) 式 为 代表 了   。

     

    (1) 式 这个 泛函方程 要怎么解?          不知道 。         基本上, 这种 方程 已经 达到 无从下手 的 境界 了   。

     

    是 什么 造成了 这种 妖怪方程 ?   数学 的 抽象  。

     

    可以 对 (1) 式 作一些 简化,   先把   Sins (t) 简化为   Sins (t) = A1 sin ( ω1 t ) + A2 sin ( ω2 t ) + A3 sin ( ω3 t )  + …… + An sin ( ωn t )   ,

    这个简化 忽略了 ψ 和 b   。

    于是,   (1) 式 变为 :

     

    ʃ  | Src (t) -  [ A1 sin ( ω1 t ) + A2 sin ( ω2 t ) + A3 sin ( ω3 t )  + …… + An sin ( ωn t ) ]  |   dt ,  [ t1, t2 ]  =   0

     

    再简化一点,  把 绝对值号 去掉,

     

    ʃ  Src (t) -  [ A1 sin ( ω1 t ) + A2 sin ( ω2 t ) + A3 sin ( ω3 t )  + …… + An sin ( ωn t ) ]   dt ,  [ t1, t2 ]  =   0

     

    积分 也 去掉 算了 ,

    Src (t) -  [ A1 sin ( ω1 t ) + A2 sin ( ω2 t ) + A3 sin ( ω3 t )  + …… + An sin ( ωn t ) ]    =   0

    A1 sin ( ω1 t ) + A2 sin ( ω2 t ) + A3 sin ( ω3 t )  + …… + An sin ( ωn t )  =  Src (t) 

     

    现在 这 方程 能 解 了 吗 ?   好像还不能,   那 把  sin ( ω1 t ) ,  sin ( ω2 t ) ,  ……   sin ( ωn t )    都 换成 常量  k1,  k2,  ……  kn,   把  Src (t)  也换成常量  S  ,

     

    k1 A1 + k2 A2 + k3 A3 + ……  kn An = S     ,       A1 , A2,  A3 , …… An  为 未知数,    k1, k2, k3, …… kn  为 常数,    S 为 常数    (4) 式

     

    这个 方程 能 解 了 吗?      可以 进一步简化,  让 n 为 有限大 的 自然数  ,

     

    k1 A1 + k2 A2 + k3 A3 + ……  kn An = S     ,       A1 , A2,  A3 , …… An  为 未知数,    k1, k2, k3, …… kn  为 常数,    S 为 常数,   n 为有限大的自然数    (5) 式

     

    (5) 式 是 一个 n 元方程,   也是一个 不定方程,   也是一个 丢番图 方程  。

     

    (5) 式 方程 怎么解  ?     当然 (5) 式 有 无穷多个 解,   那 比如,  求 最小解,  比如  A1 + A2 + A3 + …… + An  的 和 最小 的 解  。

     

    (4) 式 (5) 式 和 (1) 式  有 什么关系 ?        没有关系,     但可以 通过 (4) 式 (5) 式 类比 看看 (1) 式  要 怎么解   。

     

    那么,  要怎么来 求 得 傅里叶级数 呢 ?     可以 想点 办法  。

     

    比如,  先把 问题 简化 为  求 第一项  Sin [1]  ,     可以 先 求出 一个 正弦信号,  波形 和 源信号 相差 最小,  这就是 Sin [1] ,   然后,  让 源信号 减去 Sin [1] , 得到 的 差 记为 z  :

     

    z =  Src (t) - Sin [1]

     

    接下来 再 求 一个 正弦信号,  波形 和 z 相差 最小,  这就是 第二项  Sin [2] ,  然后,  让  z = z - Sin [2]  ,   以此类推,  求  Sin [3] ,  Sin [4] ,  ……  , Sin [n]   。

     

    先来看 怎么求 Sin [1] ,   和 上文 (1) 式  的 原理 一样,    可以 写一个 定积分 来 表示  源信号 和  Sin [1]  的 波形 差异 大小 :

     

    ʃ  | Src (t) -  Sin [1] | dt  ,     [ t1,  t2 ]

     

    让 这个 定积分 最小,

     

    ʃ  | Src (t) -  Sin [1] | dt  ,     [ t1,  t2 ]    ->    min       (6) 式

     

    (6) 式  就是 求  Sin [1]   的  泛函方程  。

     

    因为   Sin [1] = A1 sin ( ω1 t + ψ1 ) + b1  ,   代入 (6) 式 ,

     

    ʃ  | Src (t) -  A1 sin ( ω1 t + ψ1 ) -  b1 | dt  ,     [ t1,  t2 ]    ->    min       (7) 式

     

    对于   一些 简单 、规则 的 周期信号, 比如 方波, 三角波,     这些 信号 作为 源信号 的 话,  可以 不考虑  ψ1 、b1 ,

    同时, 显然,   它们 的 基波 的 周期 和 它们 一样,  即  ω1  就是 源信号 的 ω ,

    于是 (7) 式 可以 简化 为 :

     

    ʃ  | Src (t) -  A1 sin ( ω t )  | dt  ,     [ t1,  t2 ]    ->    min       (8) 式

     

    ω 已知,  就是 源信号 的 ω ,       所以,   (8) 式 中 只有一个 待定系数  A1  ,    只要 求出 A1 就可以,   这样的话,   可以试试 变分法,  看用 欧拉方程 能不能 解出来  。

     

    但  欧拉方程 的 解 是 一个 函数,   这里 的 A1 是 一个 系数,  是 常量,  这就 尴尬 了,  呵呵呵呵 。  这两者(函数 和 常量) 的 矛盾 能不能 调和 ?  期待 数学天才们 的 表演,  拭目以待 。

     

    我们 可以 画 一个 图 把 上面 的 过程 形象 的 表示出来 :

     

     

     

     

    蓝色 三角波 是 源信号,    红色 正弦波 是 基波,  也就是 傅里叶级数 的 第一项  Sin [1]  ,    红线 和 蓝线 之间 用 绿线 标出 的 区域 就是 两者 波形 的 相差,  绿线 标出 的 区域 面积 大,  则 两者波形 相差 大,   面积小, 则 波形相差小 。

     

    绿线 标出 的 区域 面积 就是 定积分   ʃ  | Src (t) -  A1 sin ( ω t )  | dt  ,     [ t1,  t2 ]     ,   (8) 式 就是 让 这个 面积 最小 。

     

    如图,  在这个 场景 里,  我们 只要 确定 A1,  使得 绿线 标出 的 区域 面积   最小 就可以  。

     

    上文 提到 可以 考虑 用 变分法,  大家 可以 自己 试试,  这里 先不讨论 。  我们 看看 用 离散 线性 样本 的 方法 。

     

    可以 大概 给 A1  划一个 范围,  把 这个 范围 切割 成 9 等分,  这样 可以 有 10 个 值,   把 这 10 个 值 代入    定积分   ʃ  | Src (t) -  A1 sin ( ω t )  | dt  ,     [ t1,  t2 ]   ,    看 哪个值 得到 的 定积分 最小,    就 取 这个 值 作为 A1,    切割 的 等分 越多,   则  结果 越 精确  。

     

    [t1, t2]   在 这里 是 一个周期  。

     

    当然,   对于 横坐标 t,  在  [ t1, t2 ]  区间 里 也要  切割一些 等分 来 近似计算积分   。     假设   [ t1, t2 ]    切割了 100 个 等分,   乘上 A1 的 10 个 值,  计算 的 时间复杂度 就是   10 * 1000 = 1 万   。

     

    这个方法 对于 一般 的 源信号,  也许 有 不错 的 近似 效果 。  但是 对于 一些 源信号,  比如 突变性 的,    就 不适用 了  。

     

     

     

     

    比如,  上图 蓝色 的 源信号,   突变 很明显 ,       合成 它 的 基波 和 谐波,  大概 要 像 图上 这样 比较合适  。

    红色 是 基波,  也就是 傅里叶级数 第一项,   橙色 是 一个 谐波,  它的 频率 是 基波 的 3 倍,   可以 认为 是 傅里叶级数 的 第三项  。

     

    显然,    基波 和 源信号 的 波形 差异 并不是 最小, 甚至 还 有点 大  。  从这里看出,   构造 傅里叶级数  需要一些  “总揽全局” 的 规划 。

    又或者说,  上面 一开始 提出 的 一项 一项 求 的 方法,  割裂了 傅里叶级数 的 “整体性”   。

     

    如果 把 傅里叶级数 的 所有项 放到一起来 考虑,   可以 简化一点, 让 n 等于一个 有限的 不太大的 自然数,  比如 n = 5,  这样就是 由 5 个 正弦信号 来 组成 源信号  。

     

    5 个 正弦信号 写成 矩阵 :

     

    A1 , ω1 , ψ1 , b1

    A2 , ω2 , ψ2 , b2

    A3 , ω3 , ψ3 , b3

    A4 , ω4 , ψ4 , b4

    A5 , ω5 , ψ5 , b5

     

    每个 正弦信号 的  A , ω , ψ , b   均 取 10 个值,  这样来匹配,  则 每个 正弦信号 会 产生出 10^4 = 1 万 个 样本,

    有 5 个 正弦信号,   5 个 正弦信号 的 样本 在一起 匹配,   会 产生出   ( 1 万 ) ^ 5 = 10^20 个 样本,

    10^20 个 样本 中 波形 和 源信号 差异 最小 的 那个 样本 就是 最优解  。

     

    10 ^ 20 ,  这个 计算量 太大 了 ,      可以简化一点,    让 ω 固定,  5 个 正弦信号 的 ω 依次为  ω ,  ω * 2  , ω * 3 ,  ω * 4 ,  ω * 5  ,   忽略 b  。

    这样 写成 矩阵 :

     

    A1 , ω , ψ1 

    A2 , 2 * ω , ψ2 

    A3 , 3 * ω , ψ3 

    A4 , 4 * ω , ψ4 

    A5 , 5  * ω , ψ5 

     

    因为 ω 是 固定 的,   每个 正弦信号 参与 取值 匹配 的 只有 A 、ψ,   所以,  每个 正弦信号 的 样本 是 10^2 = 100 个 ,

    5 个 正弦信号 组合匹配 产生 的 样本 是  100 ^ 5  = 10^10 = 100 亿  个  。

     

    这个 计算量 还是 太大, 呵呵 。  所以 这个 算法 似乎 有点 不科学,  也有点 白痴,   哈哈 。

     

    到目前为止,  这个 算法 处理的,   是 简单信号 (Simple and Pure) ,    简单信号 是指 波形 单一 、特点明显  的 周期信号,   常见 的 人造信号 很多是 简单信号,   比如 方波 、三角波 、梯形波 ,  等等  。

     

    简单信号 比较 容易 进行 傅里叶级数 分解 。

     

    自然界 中 的 信号 大多 是 复杂的,  具有 复杂 和 多样 的 波形,  即使 有 周期性,  但 也不是 一成不变 的 。

     

    自然界 中 的 信号 比如 自然界 中 的 声音,   人声 、动物的声音 、乐器的声音,  以及 自然界 中 的 各种声音 。

     

    以 声音信号 为例,    波形 表示 音色 和 音质 ,   还传达着信息,  人类语言 、动植物的声音 、大自然的声音 都 传达 着 各种各样 的 信息 。

     

    我们来看一个 声音信号,  这个 声音信号 是 我 假想 的  。

     

     

     

     

    可以 把 这个 信号 分为 3 个 信号,  也是 3 个 分量 :

     

    分量 1 :

     

     

    分量 2 :

     

     

    分量 3 :

     

     

     

     

    分量 1 的 频率 和 源信号 一样,   音调(音高) 听起来 大概 和 源信号 一样,   但 脉冲宽度窄,  这表示 脉冲本身的 频率高, 所以, 音色 中 带有 尖锐 的 特质 。  另外,   脉冲宽度窄 也 意味着 振动 能量 小,   所以, 听起来 会 比较 弱小 、细小,  总的来说, 听起来 是一个 尖细 的 声音 。

    分量 1 合成到 源信号 中,  会 让 源信号 的 音色 听起来 更丰富 。

     

    我感觉,   分量 1 听起来 是 “嘀 -” ,   分量 2  听起来 是 “嘟 -” ,  分量 3 听起来 是 “咚 -”  。   哎 ?   怎么 都是 声母 D 开头 的 ?

     

    上面 3 个 分量 都是 简单信号,   这样 的 分量 称为  频域 的 自然分量,   简称 自然分量,   又名 特征分量 。    将 信号 分解 为 自然分量 的 方法 称为 自然分解法, 又名 特征分解法  。

     

    自然分量 和 傅里叶级数 不一样,   傅里叶级数 是  一组 正弦函数,   且 每一个 正弦函数 的 频率 是 指定 的 。

     

    自然分量 不是 傅里叶级数  。

     

    要把 自然界 的 信号 分解 为 傅里叶级数 并不容易,   首先一个 问题 就是 基波 的 频率 是多少?  怎么确定 ?

     

    自然界 的 信号 通常 是 分解为 自然分量 来 进行 分析,  以 声音信号 为例,    比如 测量 音调(音高),  分离出 基因 泛音,   声纹识别 、语音识别 、各种广义的声音识别 和 声音特征分析  。

     

    自然界 的 信号 分解 为 傅里叶级数 反而 会 丢失 原始 的 特征信息 。

     

    也许, 通常,  傅里叶级数 只适合于 分解 简单信号  。

     

    将 自然界 的 信号 分解为 自然分量,   自然分量 是 简单信号,  可以 进一步 分解为 傅里叶级数 。

     

    当然,  自然界 的 信号 不是 绝对规则的, 分解 得到 的 自然分量 的 每个周期 的 波形 和 周期 也不一定 完全一样,   可以 近似等价 为  每个周期 都一样 的 规则的 、理想的 简单信号,  再 分解 为 傅里叶级数 。

    也可以 单独 取 一个 周期 的 波形 来 分解 为 傅里叶级数,  当然 也可以取 任意 一段 波形 来 分解 为 傅里叶级数  。

    也可以 将 任意 一段波形 当作 一个 周期 来 分解 为 傅里叶级数,     就像 对于 非周期信号,  将 整个信号 的 定义域 作为 一个 周期  。

     

    自然界 的 声音信号 ,  可以 通过 特征分解法 分离 出 一组 自然分量,  这组  分量 中,   振幅 明显 大于 其它 分量 的 那个 分量 称为 基音,  其它 的 分量 称为 泛音 。

    一个 声音 的 音调 由 基音 决定,   基音 的 音调 代表 声音 的 音调   。    泛音 的 音调  让 声音 听起来 层次丰富  。

     

    如果 一个 声音信号 的 分量 中,  有 2 个 分量 的 振幅 不相上下,   彼此 没有 明显优势,  那么,  这可能是 2 个 声源 的 声音,  也有可能是 一个 声源 发出了 频率 不同 的 2 个 声音 混在一起 ,   这 2 个 分量 可以认为 是  2 个 声音 的 基音  。

     

    但 事情 比这 复杂,    那 2 个 声音 各自 的 泛音 要 怎么 区分, 怎么 找出来 呢  ?

     

    这就 涉及 到 声音识别 的 问题 了,   这 涉及 到 机器识别 , 或者说 人工智能  。   比如 人类 , 或者 动物 可以 在 一堆 声音 里 识别 出 不同 声源 发出 的 声音,  可以 同时 区分 出 不同的 人 说话,  乐器,  以及 各种声音  。

     

    这涉及到 特征识别 、特征提取,     这涉及到 人工智能 和 仿生学  。

     

    为什么说 仿生学 呢 ?  因为 生物 有一套 “程序” 来 区分 和 提取 出 声音信号 中 的 各种声音  。

     

    又比如,   一群 蝙蝠 在一起,   并不会 把  其它 蝙蝠 的 超声波 和 自己 发出 的 超声波 混淆起来  。

     

    要 怎样 用 特征分解法 来 将 信号 分解为 自然分量 ?   可以看看  《卷积 毫无意义》  https://www.cnblogs.com/KSongKing/p/12839957.html   。

     

    第一次 扫描 分离出 的,   是 频率 最高 的 分量,   甚至是一些 噪点,

    第二次 扫描 分离出 的,   是 频率 第二高 的 分量,

    第三次 扫描 分离出 的,   是 频率 第三高 的 分量,

    ……

    最后一次 扫描 分离出 的,    是 频率 最低 的 分量  。

     

    说到这里,  会想到,  有时候,    特征点 和 噪点 仅 一纸之隔  。

     

    我写了一个 演示程序,  可以把 几个 正弦信号 合成为一个 合成信号  。   可以作为 学习测试 工具 。

    程序 是 用 Html 5 + javascript 写的,     项目地址 :       https://github.com/kelin-xycs/FourierStudy   。

    进入 项目页面 后, 点击 右边 的 “Clone or download” 绿色按钮,  就可以 下载 项目 了 。

    项目 里 的 程序文件 是 一个 Html 文件  SinesCompose.html ,    用 浏览器 打开 就可以运行   。

     

     

    2020-05-29      补充 :

    上文 有 这样一段话 :

    ω 已知,  就是 源信号 的 ω ,       所以,   (8) 式 中 只有一个 待定系数  A1  ,    只要 求出 A1 就可以,   这样的话,   可以试试 变分法,  看用 欧拉方程 能不能 解出来  。

     

    但  欧拉方程 的 解 是 一个 函数,   这里 的 A1 是 一个 系数,  是 常量,  这就 尴尬 了,  呵呵呵呵 。  这两者(函数 和 常量) 的 矛盾 能不能 调和 ?  期待 数学天才们 的 表演,  拭目以待 。

     

    其实不是这么回事 。         求 A1  是 一个 函数极值问题,  不需要用到 欧拉-拉格朗日 方程 。

    可以 先 把  (8) 式  里 的 定积分,  也就是  ʃ  | Src (t) -  A1 sin ( ω t )  | dt  ,     [ t1,  t2 ]    这个 定积分 的 表达式 求出来(如果能求出来的话),  怎么求呢 ?  先求  ʃ  | Src (t) -  A1 sin ( ω t )  | dt   这个 不定积分 的 表达式(如果能求出来的话),   代入 t1, t2 求 不定积分 的 差 就是 定积分,  把 定积分 记为  y = D ( A1 ) ,  即 把 定积分 看作 A1 的 函数,   求   y = D ( A1 ) 的 极值,  或者说 求  y = D ( A1 ) 的 极值条件,   即 A1 = ?  时,  D ( A1 )  取 极值 。 

    D ( A1 )  取 最小值 时 的 A1 ,  就是 要求 的 A1  。

    极值 怎么求 ?        函数极值 出现在 极值点 和 折点 。 

    极值点 是 导数 为 0 的 点, 且 点 的 两边 的 导数 异号 。

    折点 是 导数 为 无穷, 但 函数值 不是 无穷,  且 点 的 两边 的 导数 异号 的 点 。  折点 也可以 称为 不光滑极值点 。

    还有一种情况 是 单边折点,            单边折点 是 导数 为 无穷,  函数值 不是 无穷, 且 只在 点 的一边 有 函数,  另一边 没有 函数 的 点 。

    比如,   y = 根号 ( x )  ,    当 x = 0 时,  y = 0 ,   y ′ =  无穷 ,   当 x >= 0 时,   y 存在,  当 x < 0 时,  y 不存在 。

    所以,   x = 0  是  y = 根号 ( x )   的   单边折点  。

     

     

     

     

     

     

     

     

     

     

     

     

  • 相关阅读:
    Python之print字典
    SpringBoot入门 (六) 数据库访问之Mybatis
    SpringBoot入门 (四) 数据库访问之JdbcTemplate
    SpringBoot入门 (三) 日志配置
    SpringBoot入门 (一) HelloWorld
    设计模式之装饰器模式
    设计模式之模板模式
    spring之mvc原理分析及简单模拟实现
    设计模式之单例
    国产密码研究
  • 原文地址:https://www.cnblogs.com/KSongKing/p/12853392.html
Copyright © 2020-2023  润新知