[发明专利]一种用于离子推进器数值模拟的电荷交换碰撞MCC方法有效

专利信息
申请号: 201810309186.7 申请日: 2018-04-09
公开(公告)号: CN108549763B 公开(公告)日: 2021-06-01
发明(设计)人: 金晓林;叶晓辉;李斌;杨中海 申请(专利权)人: 电子科技大学
主分类号: G06F30/15 分类号: G06F30/15;G06F30/25;G06F111/10
代理公司: 电子科技大学专利中心 51203 代理人: 闫树平
地址: 611731 四川省成*** 国省代码: 四川;51
权利要求书: 查看更多 说明书: 查看更多
摘要:
搜索关键词: 一种 用于 离子 推进器 数值 模拟 电荷 交换 碰撞 mcc 方法
【权利要求书】:

1.一种用于离子推进器数值模拟的电荷交换碰撞MCC方法,具体如下:

步骤1、在GPU设备端的全局内存上开辟两段存储空间;

一段存储空间定义结构体数组,大小为能存储下模拟区域中离子推进器的所有粒子信息,即初始粒子的速度、位置和粒子属性标记信息,并且初始粒子属性标记均初始化为1,用1代表未参与电荷交换碰撞的快速粒子,用2代表参加电荷交换碰撞之后的慢速粒子;

另一段存储空间定义一个数组,大小为粒子的个数,用来存储粒子参加电荷交换碰撞判断时所需要的随机数,并将数组内的值均赋值为0;

步骤2、根据全局内存中存储的离子推进器中粒子属性标记为1的粒子个数N,调用统一计算架构平台的设备端随机数生成函数,设置随机数种子,利用GPU来产生和粒子个数N相等的随机数;每一个粒子都有一个与其对应的随机数R,用来判断该粒子是否进行电荷交换碰撞,并将所有的随机数按照数组索引的方式存放在GPU开辟的全局内存中;

步骤3、在GPU端的核函数内,根据全局内存中粒子属性标记为1的粒子个数N,并结合GPU的单指令多线程特点,分配其线程块和线程网格的大小与维度,通过线程块和线程网格的大小与维度计算得到线程的索引;

用一个线程映射一个粒子,使每一个粒子都有唯一的一个线程索引与其对应;用与粒子相对应的线程从全局内存中读取该粒子速度信息,根据读取得到的粒子的速度信息,由对应线程索引的线程计算出每个粒子碰撞截面,进而求得该粒子发生电荷交换碰撞的几率P;

步骤4、用粒子对应的线程索引的大小去索引对应的随机数数组,得到该粒子对应的随机数R;再通过该随机数R与步骤3计算得到的该粒子发生电荷交换碰撞的几率P进行大小比较,若该粒子发生电荷交换碰撞的几率P大于其对应的随机数R,则将该粒子判断为发生电荷交换碰撞,否则将其判断为不发生电荷交换碰撞;

步骤5、对于步骤4判断为发生电荷交换碰撞的粒子,做碰撞处理,即利用该粒子对应的线程去更新粒子的速度,并将该粒子的粒子属性标记为2;对于判断为不发生电荷交换碰撞的粒子,做非碰撞处理;

更新所有粒子的位置信息,并根据位置信息判断该粒子是否达到边界,若到达边界则删除粒子信息,不参与到下次的电荷交换碰撞判断过程中;

步骤6、存储未到达边界粒子的速度、位置和粒子属性信息至GPU全局内存中,并统计粒子属性标记为1的粒子个数,更新当前时刻属性标记为1粒子个数N;

步骤7、重复步骤2至6,在每个时间步长都进行离子推进器中粒子的电荷交换碰撞判断,从step=0迭代直至达到step=TOTAL,TOTAL为设置的总模拟时间步数;

步骤8、在CPU主机端定义结构体数组,大小为GPU全局内存上存储的粒子信息容量,将步骤7计算后的结果从GPU传回CPU主机端内存中,进行数据处理和分析。

下载完整专利技术内容需要扣除积分,VIP会员可以免费下载。

该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于电子科技大学,未经电子科技大学许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服

本文链接:http://www.vipzhuanli.com/pat/books/201810309186.7/1.html,转载请声明来源钻瓜专利网。

×

专利文献下载

说明:

1、专利原文基于中国国家知识产权局专利说明书;

2、支持发明专利 、实用新型专利、外观设计专利(升级中);

3、专利数据每周两次同步更新,支持Adobe PDF格式;

4、内容包括专利技术的结构示意图流程工艺图技术构造图

5、已全新升级为极速版,下载速度显著提升!欢迎使用!

请您登陆后,进行下载,点击【登陆】 【注册】

关于我们 寻求报道 投稿须知 广告合作 版权声明 网站地图 友情链接 企业标识 联系我们

钻瓜专利网在线咨询

周一至周五 9:00-18:00

咨询在线客服咨询在线客服
tel code back_top