当前位置: 首页 > news >正文

磁共振图像处理中 fft1c 和 ifft1c 函数的 Python 实现

fft1cifft1c 是 MRI 图像处理的常用函数。通常使用如下的 Matlab 实现 (Michael Lustig,2005)

function res = ifft1c(x,dim)% res = fft1c(x)
% 
% orthonormal forward 1D FFT
%n=size(x,dim);
shft=zeros(1,5);
shft(dim)=ceil(n/2);x=circshift(x,shft);fx=ifft(x,[],dim);fx=circshift(fx,shft);res = sqrt(n)*fx;function res = fft1c(x,dim)% res = fft1c(x,dim)
% 
% orthonormal forward 1D FFT
%
% (c) Michael Lustig 2005n=size(x,dim);
shft=zeros(1,4);
shft(dim)=-ceil(n/2);x=circshift(x,shft);fx=fft(x,[],dim);fx=circshift(fx,shft);res = 1/sqrt(n)*fx;

但笔者在尝试将一个需要使用 ifft1c 函数移植到 Python 中时发现,无论是现有库还是其他现有开源代码很少有 ifft1c 的 Python 实现,Github 中少数的几个实现也和 Matlab 版不同,这给 debug 带来了不便。因此此处给出笔者的 ifft1c Python 版实现,与 Matlab 版最大程度的保持了一致

ifft1c

import numpy as np
import math
import scipydef iff1c(x, dim):n = np.size(x, dim)shft = np.zeros(5, dtype=int)shft[dim] = math.ceil(n / 2)shft = tuple(shft)x = np.roll(x, shift=shft, axis=dim)  # how to deal with more than 2?fx = scipy.fft.ifft(x, axis=dim)fx = np.roll(fx, shft, axis=dim)return math.sqrt(n) * fx

fft1c

import numpy as np
import math
import scipydef ff1c(x, dim):n = np.size(x, dim)shft = np.zeros(4, dtype=int)shft[dim] = -math.ceil(n / 2)shft = tuple(shft)x = np.roll(x, shift=shft, axis=dim)  # how to deal with more than 2?fx = scipy.fft.fft(x, axis=dim)fx = np.roll(fx, shft, axis=dim)return math.sqrt(n) * fx
http://www.lryc.cn/news/102679.html

相关文章:

  • 阿里云国际站香港地域服务器访问延迟丢包的原因及解决方法
  • GULI PART.1
  • NetApp FAS2750 和 FAS2820:适用于分布式企业和从远程到核心的 FAS
  • 剑指YOLOv8改进最新MPDIoU损失函数:超越现有多种G/D/C/EIoU,23年7月首发论文,高效准确的边界框回归的损失
  • SQL-每日一题【1070. 产品销售分析 III】
  • 为何押注AI大模型的微软云,业绩增速反而不如谷歌云?
  • CDN加速服务的工作原理
  • 在CSDN学Golang云原生(Kubernetes Service)
  • 【数据结构篇C++实现】- 图
  • Sentinel持久化规则
  • list与sort()
  • 6个月、21天,GoldenDB分布式数据库核心系统落地中移动
  • 如何正确培养数据思维?
  • JavaScript中的?.和??的用法
  • Git for linux
  • uniapp小程序,根据小程序的环境版本,控制的显页面功能按钮的示隐藏
  • kotlin 编写一个简单的天气预报app(二)增加搜索城市功能
  • 【分布鲁棒、状态估计】分布式鲁棒优化电力系统状态估计研究[几种算法进行比较](Matlab代码实现)
  • vue中的require
  • Linux进程间共享内存通信时如何同步?(附源码)
  • spring注解驱动开发(二)
  • 【C++】——类和对象
  • 【Docker】使用docker-maven-plugin插件构建发布推镜像到私有仓库
  • 区块链学习笔记
  • 实用上位机--QT
  • os.signal golang中的信号处理
  • Python源码:Tkinter组件布局管理的3种方式
  • 网络防御之VPN
  • VUE使用docxtemplater导出word(带图片) 踩坑 表格循环空格 ,canvas.toDataURL图片失真模糊问题
  • ubuntu 安装 Pycharm社区版