资源描述:
第 40 卷 第 3 期 电 子 科 技 大 学 学 报 Vol.40 No.3 2011年5月 Journal of University of Electronic Science and Technology of China May 2011 海量地形三维仿真系统的设计与实现 许文波1,李 莉2,周虹霞3,黄健熙4,黄 波1 1. 电子科技大学自动化工程学院 成都 610054; 2. 四川电力科学研究所 成都 610072 3. 四川省军区军训教研室 成都 610041; 4. 中国农业大学信息与电气工程学院 北京 海淀区 100083 【摘要】在CTS和Vegaprime软件的基础上,建立海量地形三维仿真系统。收集中国福建省的ETM数据和数字高程模型数 据,预处理后利用CTS软件生成虚拟纹理和地形格网,并进行纹理映射。在VegaPrime下引用地形格网和虚拟纹理形成三维的 海量大地形场景,并基于MFC环境下实现海量大地形三维仿真系统。通过采用虚拟纹理技术、层次细节模型、大地形数据的 组织、地形纹理的映射技术、大地形碰撞检测技术、大地形调度技术,解决了在大区域尺度下海量地形数据漫游的难点。 关 键 词 大地形; 三维仿真; 虚拟纹理 中图分类号 TP315 文献标识码 A doi10.3969/j.issn.1001-0548.2011.03.018 The Design and Implemention of a Large Area Terrain 3D Simulation System XU Wen-bo1, LI Li2, ZHOU Hong-xia3, HUANG Jian-xi4, and HUANG Bo1 1. School of Automation Engineering, University of Electronic Science and Technology of China Chengdu 610054; 2. Sichuan Electric Power Research Insititute Chengdu 610072; 3. Military Teaching and Research Section, Sichuan Provincial Military District Chengdu 610041; 4. College of Ination and Electrical Engineering, China Agricultural University Haidian Beijing 100083 Abstract Based on creator terrain studio CTS and Vega Prime, this paper manages to build up the massive terrain 3D simulation system. By preprocessing database of ETM and DEM in Fujian, virtual texture and topographic pattern are generated by CTS. After texture mapping, a 3D massive terrain scene is created by using of Vega Prime and finally massive terrain 3D simulation system is realized based on MFC. The application of virtual texture, level of detail model, organization of massive terrain database, terrain texture mapping, large terrain collision detection, and large terrain dispatching technology is helpful in solving large scale image and terrain roaming. Key words lands; three-dimensional simulation; virtual textures 收稿日期 2010 − 03 − 30; 修回日期2011 − 01 − 29 基金项目 国家重点基础研究发展规划2007CB714407 作者简介许文波1973 − ,男,博士,副教授,主要从事遥感信息处理及应用方面的研究. 海量三维大地形系统一直是视景仿真领域研究 的热点和难点。从90年代中期开始,美国Skyline公 司开发了Skyline TerraSuite三维GIS软件,能够无缝 集成航空影像、卫星数据、数字高程模型和其他2D 或3D信息源,包括GIS数据集层。它在快速数据融 合、更新数据库、支持大型数据库和实时信息流通 信技术等方面具有显著的优势。该软件还提供了二 次开发工具为用户提供定制和功能扩充服务,但它 在复杂三维实体的建模方面功能较弱,而且购买价 格比较昂贵。2005年6月底,Google公司在Keyhole 公司开发的EarthView基础上推出了桌面工具 Google Earth,是目前最完善的海量遥感影像数据服 务平台,较好地实现了海量影像、DEM和矢量数据 的传输、 可视化等功能。 微软公司推出的MSN Virtual Earth Beta版能够在线显示45视野的街道卫星地图 以及覆盖式的街道影像,但不能无级放大地图,下 载速度不够理想。 三维仿真系统可广泛应用于军事、房地产、航 空航天、教育、娱乐、工程施工、城市规划等行业[1]。 在军事模拟训练领域,文献[2]实现舰炮射击模拟训 练系统, 该训练系统利用Vega结合Creator进行开发, 建立了桌面式的仿真沙盘系统;文献[3-4]进行了协 同作战、弹舰电子对抗等类似系统的开发研究;在 城市规划与建设领域,文献[5]利用Vega仿真引擎结 第3期 许文波,等 海量地形三维仿真系统的设计与实现 419 合VC6.0编程实现了佛山市城市规划电子沙盘系 统;文献[6]应用ArcGIS的内置定制环境VBA对 ArcGIS应用程序进行客户化,设计并实现了重庆市 区域规划电子沙盘系统;文献[7]研制的南水北调电 子沙盘系统,是南水北调工程仿真系统的重要组成 部分。 本文基于VegaPrime和CTS creator terrain studio 开发了一个具有通用功能的大地形三维仿真系统, 通过动态实时调度取舍地形瓦片,实现了大地形海 量数据的显示以及虚拟纹理的正确映射,并在此基 础上基于MFC平台开发了9个功能模块。基于该系 统,可以做进一步的行业定制,形成面向更为特定 行业应用的三维电子沙盘。 1 研究区介绍 本文以福建省为研究区,具体经纬度范围为东 经115.256~119.996,北纬27.905~24.151,总计 面积约为21万平方公里其中包括了海域面积。 该区 域的地貌特征为多丘陵和山地,少平原,平均海拔 不高,大部分地区在海拔1 000 m以下,东南部为海 域,西北方向的海拔也很低。 2 数据准备与预处理 一个显示内容丰富、层次性好、漫游自然流畅 的电子沙盘一般应包括地形数据、地形纹理和3D模 型等。 2.1 地形数据 本文系统采用的DEM数据是美国国家航空航 天局NASA发布的世界范围的数字高程数据 SRTM3。福建省全覆盖数据共16景,数据大小约为 1.2 GB。 2.2 纹理数据 纹理数据来源于NASA的地球资源卫星系列的 LandSat 5上的专题制图仪thematic mapper,TM所 获取的多波段扫描影像。TM有7个波段,其影像的 空间分辨率除了热红外波段为120 m外,其余均为 30 m,像幅185 km185 km。本文采用5、4、3波段 彩色合成,福建全省覆盖共16景数据,数据大小约 为3 GB。 2.3 3D模型 在实时仿真特别是军事上的仿真中采用大量的 3D模型,用户可以动态加载这些模型到场景中与场 景完成交互,如电子沙盘里面常用到的旗帜标注。 Vega Prime主要支持FLT格式的3D模型, 其本身提供 了一个FLT的3D标准模型库,如果库中没有需要用 的模型,可以使用Creator软件制作。 2.4 地形数据与纹理数据的预处理 DEM数据需要进行的预处理主要包括拼接和 裁剪。TM数据需要先进行波段的组合,形成彩色影 像,本文选择5、4、3波段合成。将波段合成的TM 数据进行拼接与裁剪处理。 CTS要求DEM数据和TM 纹理数据有一致的投影坐标信息,因此最后还需要 对两类数据进行投影以及数据格式的转换。 2.5 虚拟纹理和地形格网的生成 将经过预处理后的数据在CTS里利用纹理和地 形向导的进程流水线生成虚拟纹理和地形格网。重 要的参数设置主要有1 合理地设置虚拟纹理的层 数以保证纹理的精度能得到最好的利用,CTS通过 地面采样距离ground sample distance,GSD反映采 样精度。以本文为例,TM的精度是30 m,每一经纬 度大约是111 km,所以最高层纹理的GSD不得小于 1111 000/30 3 700,CTS面板显示虚拟纹理取为 16,则X、Y方向的GSD分别为6 912.225 089、 8 728.896 574, 所以本文中取16或更高层即可; 2 合 理地设置LOD最高层地形的瓦片数以保证精度最高 的纹理能够映射到LOD最高的地形上。在CTS中地 形格网和虚拟纹理都是以层次和瓦片的形式组织 的,当地形瓦片小于、等于纹理瓦片时,最适合的 那层纹理会被映射到相应的地形上,如果地形瓦片 比纹理瓦片大,系统只有取精度次之的纹理中的瓦 片进行比较。本文的纹理取了16层,精度最高层瓦 片大小为0.074 0720.058 656,而地形的瓦片大小 需要根据地形的Coverage与纹理是一致的与Grid Structure中的LOD层次划分确定。 Coverage的经纬度 范围是东经115.256~119.996,北纬27.905~ 24.151,即X方向为4.764,Y方向为3.734,按照上 面描述的原则, X方向的地形瓦片数应该大于、等于 4.764/0.074 072 64.32,Y方向的地形瓦片数应该大 于、等于3.734/0.058 656 63.66。地形向导生成的 LOD是5层,但其最高层LOD4的瓦片数是3232, 显然不够X、YRow和Col的变化率。LOD4地形中 的瓦片数是12864,足够满足地形纹理瓦片大小 原则。 CTS提供了两种纹理瓦片最后能保存的格式 DDS和5551,前者是一种压缩格式,而且在实时运 行时表现的品质不比5551差,本文采用5551格式的 电 子 科 技 大 学 学 报 第 40 卷 420 纹理。通过设置适当的参数运行CTS后生成了 3.4 GB的数据, 最后一个Convert进程生成了683 MB 的5551格式的最终纹理。 3 系统及功能设计 本文的系统核心是以虚拟纹理和地形格网为基 础的三维实时场景,系统功能都是基于该场景开发 的。纹理和地形的生成来源于卫星遥感数据,实体 模型来源于MultiGen-Paradgim Creator模型库以及 利用Creator自行制作的模型。在大地形场景的基础 上设计了9个功能模块, 每个功能模块下有若干子功 能,系统框架图如图1所示。 DEM 数据 TM 遥感影像 大地形模型 一般实体模型 VegaPrime 驱动 大地形电子沙盘系统 视图控制 标 注 漫 游 运动模式 环境控制 地形分析 实用功能 投影模式 坐标显示 图1 系统框架图 4 系统软件平台 系统基于VegaPrime开发, MultiGen-Paradigm的 Vega/VegaPrime系列是国内最受用户欢迎的视景仿 真驱动引擎,有调查显示,目前在国内做视景仿真 或者虚拟现实的,一半以上57.5使用的都是 Vega Prime包括Vega系列。Vega早在2003年就已经 停 止 升 级 了 , MultiGen-Paradigm 现 在 致 力 于 VegaPrime新版本的开发。VegaPrime基于VSGvega scene graph开发,而Vega基于SGI公司的Perfomer 场景图管理系统开发,Perer只能支持OpenGL, 而VSG在一定程度上也支持DirectX;Vega基于C语 言, 而VegaPrime使用C开发, 融入了很多现代C 的特性和技术,如设计模式和泛型;Vega的ACF文 件是文本格式,而VegaPrime采用的是XML格式。 系统的地形和纹理是通过CTScreator terrain studio处理的, CTS是MultiGen-Paradigm开发的致力 于处理大地形数据的软件,在功能上大大超过 Creator的地形处理模块Terrain Pro。CTS采用进程流 的方式,通过若干个进程的接力处理,可以方便地 直接将原始DEM和纹理数据转换为地形格网和虚 拟纹理。 系 统 功 能 的 开 发 环 境 是 Microsoft Visual Studio.NET 2003,此外地形和纹理数据的处理还借 助了ERDAS、Global Mapper、Photoshop CS、 MicroDEM等软件。 5 关键技术 本文首先利用原始遥感影像在CTS中生成所需 的虚拟纹理virtuall texture, 然后根据虚拟纹理的分 层分块结构生成分层的LOD地形, 在Vega Prime中通 过LADBM大地形管理模块进行分块动态载入,最 后在VC2003编程环境下与地形做碰撞检测实现 交互。 5.1 虚拟纹理及其与地形格网的映射 电子沙盘由于地形一般较大,与之对应的纹理 范围也非常大,为了达到真实感,纹理分辨率一般 也比较高。因此,一块纹理的大小往往超出了显存 的大小,所以如果加优化处理,仅仅一次显示单块 纹理的做法将超出硬件的处理能力。 VegaPrime/CTS 利用Virtual Texture技术解决以上问题。 Virtual Texture VT技术源于SGI平台下的 Clipmapping技术,它是以层Level瓦片Tile的结 构组织的。层级从11的纹理开始,逐层2倍增加, 一直到最高层。每层均覆盖整个地形。从第1层到第 9层均为1张纹理覆盖整个地形,尺寸长宽方向上的 象素数目从11~512512。从第10层开始,按照 512512大小进行分块,即第10层有22张512512 的纹理,第11层有44张512512的纹理,一直到最 高层[8]。 地形格网与虚拟纹理类似,也是层瓦片的形 式,地形的层称为LODlevel of detail。地形的层次 一般不会像纹理那样多,尤其是大地形的仿真,一 般4层左右就合适。在进行纹理映射时,精度最高层 的纹理瓦片映射到最高层LOD的地形瓦片,然后精 度次之的纹理瓦片映射到次层LOD的地形瓦片。 5.2 多层LODlevel of detail 细节层次技术是在不影响实际仿真效果的前提 下, 通过逐次简化模型的细节来降低模型的复杂度, 从而提高场景渲染的效率。对应于虚拟纹理的分层 结构,3D地形生成也需要进行合理地分层/分块处 理;而且在对应的层上,地形分块的大小必须小于、 第3期 许文波,等 海量地形三维仿真系统的设计与实现 421 等于纹理分块的大小,这样才能显示出相应层最高 精度的纹理。另外,地形的分层和VT的分层不同, 按照LOD分层设置,分成4~6层即可满足应用要 求[8]。本文考虑到30 m分辨率纹理的显示,将地形 分为4层LOD,并根据多边形数目限制及视锥的参 数,设置了合理的LOD距离及每层LOD的多边形构成。 在CTS生成虚拟纹理和地形LOD的过程中,会 根据分块纹理/分块地形的层次级别,自动生成文件 目录结构,并生成一个特定的MetaFlight文件,通知 VegaPrime如何匹配和调用这些分块文件。 5.3 大地形分块调度技术 VegaPrime 的 大 面 积 数 据 库 管 理 large area database management,LADBM是为满足海量数据 数据库调度而设计的,特别针对庞大的数据库在动 态场景中瓦片的调度和数据集的装载及组织。有了 LADBM和MetaFlight格式的结合,大型数据集之间 的协作变得更有效, MetaFlight的分级数据结构也在 实时场景被优化的同时得到维持。VegaPrime的核心 功能包括双精度double precision、多线程multiple threading、MetaFlight和LADBM,共同为大面积虚 拟仿真提供了一个优化的解决方案。 在LADBM中, 用户需要关心的Dataset实际上就 是GeometryGridDatasets。 GeometryGridDatasets是一 种多层格网结构,格网在每层将地形在空间上分成 一个个独立的瓦片,不同的层代表相同区域的不同 细节层次LOD,高细节层次部分细分低细节层次 部分,比如第3层的一个瓦片应该覆盖第4层上相同 区域的4个瓦片。父层总是完全包含了子层,子层绝 不会跨越父层瓦片的边界[9]。GeometryGridDatasets 的层次结构如图2所示。 第 0 层 最底层 LOD 第 2 层 上一层 LOD 第 3 层 最上层 LOD 第 1 层 上一层 LOD 纬度 经度 图2 GeometryGridDatasets层次结构 一般来说有两种页面调度策略,一种是简单地 将整个数据集全部调度进来,适用于小型数据集; 另 一 种 是 在 场 景 图 的 坐 标 中 定 义 一 个 位 置 position,以这个位置为中心拣选瓦片,称为点调 度策略paging strategy point,PSP。如果场景图与 格网不是相同的坐标系统, PSP先要将场景图的位置 坐标转换为格网坐标,同时判断每层格网的哪些细 胞cell在策略位置点strategy’s position point的调 度范围内,只将在该范围内的瓦片调进场景。当策 略位置点移动,不再是调度范围内的瓦片将被调出 场景, 同时调进进入策略范围的新瓦片。LADBM的 调度中心点可以依附attached到VegaPrime的任何 物体上只要是vpPositon及其派生类的对象就行。 PSP不一定是跟随视点的, 它能被移动到场景中的任 何一点。同时,VegaPrime支持一个场景中使用多个 调度策略,比如在场景中设置2个通道,各通道可以 有自己的调度策略。唯一的限制是依附到场景即调 度策略的所有数据集要求有相同的坐标系统[10-11]。 本文归纳总结LADBM在VegaPrime中的工作流 程如下 1 如果格网坐标系统与数据坐标系统不一致, 将策略位置坐标转换到格网坐标; 2 从LOD的最低层次开始,找出瓦片包含策略 位置点或者最接近策略位置点。 如果最接近策略位 置点的瓦片不在策略的范围range内,就不会有页 面调度,反之提交一个调度该瓦片的请求; 3 检查所有的相邻瓦片是否满足调度范围直 到超出调进范围page-in range,提交调度所有满足 条件的瓦片的请求; 4 提交调出不再满足调度范围的瓦片的请求; 5 进入LOD的下一个层次,重复步骤2~4, 直到所有层次都被处理。 5.4 碰撞检测技术 碰撞检测是构造仿真系统不可缺少的一个重要 部分,它可以使用户以更自然的方式与仿真系统中 的场景对象进行交互。虚拟视景中动态物体与静态 物体之间或动态物体与动态物体之间,以及用户与 场景之间的交互基础就是碰撞检测。 在 VegaPrime 中 碰 撞 检 测 器 被 封 装 成 类 vpIsector,它是由一些线段组成的,使用起来很简 单,把检测器放置于仿真物体上随之一起运动,设 置碰撞检测的目标,当这些线段与目标物发生相交 时即认为碰撞发生。具体的使用方法有两种 1 在程序的主循环中设定检测器的位置,调用 其update成员函数进行与目标物的碰撞检测计算, 然 后查询检测结果。该方法效率较低,尤其当目标物 很复杂时,其几何结构体由很多个子节点组成,要 分别遍历它的各个子节点以进行碰撞检测计算,将 会耗费很长时间; 2 使用服务类vpIsectorService。该方法涉及到 电 子 科 技 大 学 学 报 第 40 卷 422 碰撞检测的消息机制,当碰撞发生时,碰撞检测器 会自动通知它的消息订阅者,后者接到消息时就可 以根据碰撞检测的结果做相应处理。 碰撞检测器与目标物都有各自的掩码,二者需 要分别设定,只有当它们做与运算的结果不为零时 才进行碰撞检测,这样可以避免检测器与非相关对 象进行碰撞检测。在VegaPrime中常用的碰撞检测器 有vpIsectorHAT、vpIsectorLOS、vpIsectorBump、 vpIsectorZ、vpIsectorZPR和vpIsectorTripod等,它们 都是以vpIsector为基类建立的类。 vpIsectorHAT height above terrain适用于高空 飞行模拟,检测器从其中心垂直向下射出一条直线 直达地表面,可实时计算目标到地表面的距离,并 获得目标在地表面的垂直投影点。VpIsectorLOS line of sight是基于视线的碰撞检测器,如图3a所 示,自视点P沿视线方向y轴正方向延伸出一条线 段,距离为rr由用户设定,终点为Q,将检测器安 置于仿真对象上,可实时探测到仿真对象的前方距 离r内最近的物体。vpIsectorTripod由平行于z轴的3 条等长且等高的线段组成,如图3b所示,宽度width 和长度height确定了3条线段之间的位置关系。它适 于放置在运动载体上,当载体行驶于不平坦的地面 上时,检测器的3条线段与地面的3个交点构成了一 个平面α,根据检测器的方位角以及平面α的法线, 容易计算出载体的俯仰角和滚动角。vpIsectorBump 则分别自中心点向x、y和z轴正负共6个方向上引出6 条线段,各条线段长度均可设定,如图3c所示,任 意一条线段与目标物相交时均认为有碰撞发生。另 外,用户也可根据需要从vpIsector派生出自己的碰 撞检测器。 z Q y r x P Zmax Zmin Zmin Zmin Zmax Zmax 长度 宽度 中心 a. LOS b. Tripod 高度 长度 宽度 −高度 −宽度 −长度 c. Bump 图3 VegaPrime的几种碰撞检测器 6 系统功能实现 本文将三维仿真系统做成一个Windows窗体程 序, 使用MFC microsoft foundation classes类库是最 好的选择。 MFC下的VegaPrime开发首先要解决在哪 个 窗 口 显 示 三 维 场 景 以 及 在 什 么 地 方 执 行 VegaPrime循环两个问题。对于第一个问题,因为在 MFC中获取一个窗口类的句柄很容易,所以只要确 定一个窗口作为VP窗口的父窗口, 让VP场景在父窗 口中显示就可以了。父窗口的类型是没有限制的, 如可以将一个对话框、一个View窗口、甚至一个对 话框上面的控件作为VP的父窗口。对于第二个问 题,有线程方式和定时器方式两种处理方式,线程 方式是在MFC中新开一个子线程,让VP在该子线程 里面执行主循环,定时器方式是在CMFCView类的 OnCreate方法里面进行初始化,并设置一个Timer, 然后在OnTimer函数中执行主循环。 本文采用定时器 方式实现系统界面。 本文在界面的基础上实现了视图控制、标注、 漫游、运动模式、地形分析、投影模式、环境设置、 实用功能和观察者坐标显示共9个功能模块, 由于篇 幅的原因不做详细功能介绍。三维仿真系统主界面 如图4所示。本文实现的系统包含2万个左右的三维 几何模型, 三维场景加载速度小于40 s, 漫游刷新率 大于30 Hz。 图4 三维仿真系统主界面 7 结 论 本文深入探讨了基于CTS/VegaPrime 平台的大 地形三维仿真系统的实现方法,通过采用福建省90 米格网分辨率DEM 数据、30 m分辨率TM遥感影像 进行大区域的三维地形建模,开发了一个基于MFC 的大地形三维仿真系统,实现了系统基本功能。在 第3期 许文波,等 海量地形三维仿真系统的设计与实现 423 技术层面,该文通过虚拟纹理及其与地形格网的映 射、大地形分块调度技术、碰撞检测技术的应用, 解决了在大区域地形海量数据的电子沙盘漫游的难 点问题。系统为三维仿真系统的研制与应用提供了 参考价值。 参 考 文 献 [1] 杨进, 李程, 费立凡. 基于CTS的大地形仿真应用研究[J]. 测绘科学, 2008, 331 185-187. YANG Jin, LI Cheng, FEI Li-fan. Research on application of large-area terrain simulation based on CTS[J]. Science of Surveying and Mapping, 2008, 331 185-187. [2] 赵伟, 吴旭光, 成静. 基于VR技术的舰炮射击模拟器研 究与设计[J]. 计算机仿真, 2008, 2512 301-304. ZHAO Wei, WU Xue-guang, CHENG Jing. Research and design of naval gun firing simulator based on virtual reality technology[J]. Computer Simulation, 2008, 2512 301-304. [3] 王金华, 严卫生, 高立娥. 协同作战视景仿真系统的开发 [J]. 计算机仿真, 2009, 261 98-102. WANG Jin-hua, YAN Wei-sheng, GAO Li-e. Develepment of visual simulation system for CEC counterplan[J]. Computer Simulation, 2009, 261 98-102. [4] 龚铮, 张科. 弹舰电子对抗的视景仿真技术研究和应用 [J]. 弹箭与制导学报, 2008, 281 219-222. GONG Zheng, ZHANG Ke. Research and application of visual simulation technology of ecm between antiship missile and ship[J]. Journal of Projectiles Rockets Missiles and Guidance, 2008, 281 219-222. [5] 任波, 陈汭新, 李利军, 等. 城市规划电子沙盘系统设计 [J]. 计算机与数字工程, 2005, 3410 124-126. REN Bo, CHEN Rui-xing, LI Li-jun, et al. System design of urban planning electronic sand table[J]. Computer Digital Engineering, 2005, 3410 124-126. [6] 王黎明, 文辉, 王英. 重庆市区域规划电子沙盘系统的设 计与实现[J]. 地理研究, 2004, 242 304-309. WANG Li-ming, WEN Hui, WANG Ying. Design and realization of electronic sand table system for regional planning of Chongqing[J]. Geographical Research, 2004, 242 304-309. [7] 姚宏伟, 涂颖. 南水北调电子沙盘系统的研究与开发[J]. 系统仿真学报, 2002, 1412 1598-1602. YAO Hong-wei,TU Ying. The study and development of the sand table system[J]. Journal of System Simulation, 2002, 1412 1598-1602. [8] 黄健熙, 毛锋, 许文波, 等. 基于VegaPrime的大型流域 3D管理系统实现. 系统仿真学报[J]. 2006, 1810 2819-2824. HUANG Jian-xi, MAO Feng, XU Wen-bo, et al. Implementation of large area valley simulation system based on vegaPrime[J]. Journal of System Simulation, 2006, 1810 2819-2831. [9] MultiGen Paradigm Inc. Creator terrain studio user’s guide[M]. 2nd ed. [S.l.] MultiGen-Paradigm Inc, 2006. [10] MultiGen Paradigm Inc. Vega prime programmer’s guide[M]. 2nd ed. [S.l.] MultiGen-Paradigm Inc, 2005. [11] MultiGen Paradigm Inc. Vega prime options guide[M]. 2nd ed. [S.l.] MultiGen-Paradigm Inc, 2005. 编 辑 黄 莘
展开阅读全文