CN108681446A - 基于组件服务的众创性气候算法管理系统及方法 - Google Patents

基于组件服务的众创性气候算法管理系统及方法 Download PDF

Info

Publication number
CN108681446A
CN108681446A CN201810448353.6A CN201810448353A CN108681446A CN 108681446 A CN108681446 A CN 108681446A CN 201810448353 A CN201810448353 A CN 201810448353A CN 108681446 A CN108681446 A CN 108681446A
Authority
CN
China
Prior art keywords
algorithm
weather
entity
language
invasive
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
CN201810448353.6A
Other languages
English (en)
Other versions
CN108681446B8 (zh
CN108681446B (zh
Inventor
王国复
孙除荣
邵鹏程
张杰坦
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Nanjing Enruite Industrial Co Ltd
National Satellite Meteorological Center
Original Assignee
Nanjing Enruite Industrial Co Ltd
National Satellite Meteorological Center
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Nanjing Enruite Industrial Co Ltd, National Satellite Meteorological Center filed Critical Nanjing Enruite Industrial Co Ltd
Priority to CN201810448353.6A priority Critical patent/CN108681446B8/zh
Publication of CN108681446A publication Critical patent/CN108681446A/zh
Application granted granted Critical
Publication of CN108681446B publication Critical patent/CN108681446B/zh
Publication of CN108681446B8 publication Critical patent/CN108681446B8/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/20Software design

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Stored Programmes (AREA)
  • Devices For Executing Special Programs (AREA)

Abstract

本发明公开了一种基于组件服务的众创性气候算法管理系统,包括算法配置数据库、算法编译模块、算法校验模块、算法注册模块、算法加载模块以及算法执行模块;所述算法配置数据库含有气候算法的算法实体、算法配置信息以及输入输出规范;算法配置信息包括气候算法的元数据信息以及气候算法的输入输出参数;本发明还公开了一种基于组件服务的众创性气候算法管理方法,包括以下步骤:建立算法配置数据库;算法编译;算法校验;算法注册;算法加载;算法执行。本发明能解决用一种编程语言对多种算法语言的服务封装,解决算法重复建设,资源浪费的问题,可实现气候算法的复用。

Description

基于组件服务的众创性气候算法管理系统及方法
技术领域
本发明涉及算法管理技术领域,尤其涉及一种基于组件服务的众创性气候算法管理系统及方法。
背景技术
在气候监测预测业务中,存在大量的专业的天气学算法、动力算法和统计算法,算法实现一般使用ncl、fortran、grads、python等,算法本身比较零散,目前其他业务平台还没有很好的技术手段将这些算法统一到一个平台下,并且实现气候算法能够很好的复用和继承。
发明内容
本发明的目的是针对上述现有技术的不足,提供一种基于组件服务的众创性气候算法管理系统及方法,本发明用一种编程语言(如java)对多种算法语言(ncl、fortran、grads、python等)进行服务封装,解决算法重复建设,资源浪费的问题。
为实现上述技术目的,本发明采取的技术方案为:基于组件服务的众创性气候算法管理系统,包括算法配置数据库、算法编译模块、算法校验模块、算法注册模块、算法加载模块以及算法执行模块;
所述算法配置数据库含有气候算法的算法实体、算法配置信息以及输入输出规范;所述算法配置信息包括气候算法的元数据信息以及气候算法的输入输出参数;
所述算法编译模块用于对气候算法的算法实体进行编译;
所述算法校验模块用于校验气候算法的输入输出参数是否符合输入输出规范;
所述算法注册模块用于对所述气候算法的算法实体进行注册、封装,在JavaSpring框架下编写Java调用代码实现对气候算法的算法实体的调用,然后利用Spring自定义标签技术及Spring依赖注入技术将算法配置信息及气候算法的算法实体注册到系统中;
所述算法加载模块用于根据业务流程组装需要的组件,并基于多线程和XML配置实现对所述组件的加载控制;
所述算法执行模块用于气候算法的算法实体的调用执行;所述算法执行模块采用Java RMI远程调用技术发布框架,将所述组件以服务的方式对外发布,供人机交互Web服务层调用执行。
进一步的,所述气候算法的算法实体的编写语言为NCL语言、Java语言、Fortran语言、Python语言或Grads语言。
进一步的,所述气候算法的算法实体的编写语言为脚本语言,当编写语言为脚本语言时,不需要对气候算法的算法实体再进行编译。
进一步的,所述算法加载模块可根据执行方式的不同将执行线程池分为实时交互线程池和自动作业线程池,并根据具体的人机交互和自动作业的需求对所述实时交互线程池和自动作业线程池的线程个数的比例关系进行调整。
进一步的,所述基于组件服务的众创性气候算法管理系统还包括算法替换、修改与共享模块,用于在气候算法注册、封装后对气候算法的算法实体进行算法替换、算法修改以及算法共享。
本发明还提供一种基于组件服务的众创性气候算法管理方法,包括以下步骤:
步骤1,建立算法配置数据库:在系统中建立算法配置数据库,将气候算法的算法实体、算法配置信息以及输入输出规范输入算法配置数据库;所述算法配置信息包括气候算法的元数据信息以及气候算法的输入输出参数;系统可通过气候算法的元数据信息找到气候算法的算法实体;
步骤2,算法编译:在编译器中对气候算法的算法实体进行编译;
步骤3,算法校验:系统对所述气候算法的输入输出参数是否符合输入输出规范进行校验,如果符合输入输出规范,则进行步骤4;如果不符合输入输出规范,则需要修改后重新进行步骤2;
步骤4,算法注册:在Java Spring框架下编写Java调用代码实现对气候算法的算法实体的调用,然后利用Spring自定义标签技术及Spring依赖注入技术将算法配置信息及气候算法的算法实体注册到系统中;
步骤5,算法加载:根据业务流程在系统中组装需要的组件;基于多线程和XML配置,系统可对所述组件进行加载控制;
步骤6,算法执行:采用Java RMI远程调用技术发布框架,将所述组件以服务的方式对外发布,供人机交互Web服务层调用执行;
进一步的,所述气候算法的算法实体的编写语言为NCL语言、Java语言、Fortran语言、Python语言或Grads语言。
进一步的,所述气候算法的算法实体的编写语言为脚本语言,并跳过步骤2,直接进行步骤3。
进一步的,所述步骤5,算法加载中,根据执行方式的不同将执行线程池分为实时交互线程池和自动作业线程池,并根据具体的人机交互和自动作业的需求对所述实时交互线程池和自动作业线程池的线程个数的比例关系进行调整。
进一步的,所述基于组件服务的众创性气候算法管理方法还包括以下步骤:
算法替换、修改与共享:所述气候算法注册到系统中后,还可以对气候算法的算法实体进行算法替换、算法修改以及算法共享。
本发明解决用一种编程语言(如java)对多种算法语言(ncl、fortran、grads、python等)的服务封装,解决算法重复建设,资源浪费的问题,利用这一技术实现气候算法的复用,算法继承、算法不断完善的业务需要以及基于此平台实现科研成果向业务的转化。
附图说明
图1是本发明基于组件服务的众创性气候算法库的管理系统及方法原理图
具体实施方式
下面结合附图对本发明作进一步描述。以下实施例仅用于更加清楚地说明本发明的技术方案,而不能以此来限制本发明的保护范围。
实施例1
如图1所示,本发明实施例1是一种基于组件服务的众创性气候算法管理系统,包括算法配置数据库、算法编译模块、算法校验模块、算法注册模块、算法加载模块、算法执行模块以及算法替换、修改与共享模块;
所述算法配置数据库含有使用NCL语言、Java语言、Fortran语言、Python语言、Grads语言或脚本语言等计算机语言编写的气候算法的算法实体、包括气候算法的元数据信息以及气候算法的输入输出参数的算法配置信息以及自定义的输入输出规范;
通过算法编译模块对气候算法的算法实体进行编译,当编写语言为脚本语言时,不需要对气候算法的算法实体再进行编译;
通过算法校验模块校验气候算法的输入输出参数是否符合输入输出规范;符合时,则进行算法注册,否则需对气候算法的输入输出参数进行修改后再重新进行编译、校验。
通过算法注册模块用于对所述气候算法的算法实体进行注册和封装,通过编写在Java Spring框架下的Java调用代码实现对气候算法的算法实体的调用,并通过Spring自定义标签技术将算法配置信息配置到所述Java调用代码中,然后利用Java Spring依赖注入技术将Java调用代码调用的气候算法的算法实体进行注册和封装;
通过算法加载模块根据业务流程组装需要的组件,并基于多线程和XML配置实现对所述组件的加载控制;算法加载模块还可根据执行方式的不同将执行线程池分为实时交互线程池和自动作业线程池,并根据具体的人机交互和自动作业的需求对所述实时交互线程池和自动作业线程池的线程个数的比例关系进行调整。
通过算法执行模块用于气候算法的调用执行;所述算法执行模块采用Java RMI远程调用技术发布框架,将所述组件以服务的方式对外发布,供人机交互Web服务层调用执行。
通过算法替换、修改与共享模块可在气候算法注册、封装后对气候算法的算法实体进行算法替换、算法修改以及算法共享。
实施例2
本实施例2采用Java Spring技术对各种气候算法(ncl、fortran、grads、python、脚本语言)进行封装,实现将气候算法组件化,并最终发布服务,并针对现有的算法支持上传、下载、修改替换和还原等功能,其具体包括:
一种基于组件服务的众创性气候算法管理方法,用于管理气候算法,气候算法可以是用NCL、JAVA、Fortran、Python、Grads或脚本语言等类型的计算机语言实现,主要经过以下步骤:
步骤1,建立算法配置数据库:在系统中建立算法配置数据库,将气候算法的算法实体、算法配置信息以及输入输出规范输入算法配置数据库;所述算法配置信息包括气候算法的元数据信息以及气候算法的输入输出参数;系统可通过气候算法的元数据信息找到气候算法的算法实体;
步骤2,算法编译:在编译器中对气候算法的算法实体进行编译;若气候算法的编写语言时脚本语言则不需要编译,可以跳过此步骤;
步骤3,算法校验:系统对所述气候算法的输入输出参数是否符合输入输出规范进行校验,如果符合输入输出规范,则进行步骤4;如果不符合输入输出规范,则需要修改后重新进行步骤2;
步骤4,算法注册:在Java Spring框架下编写Java调用代码实现对气候算法的算法实体的调用,并通过Spring自定义标签技术将算法配置信息配置到所述Java调用代码中,然后利用Java Spring依赖注入技术将Java调用代码调用的气候算法的算法实体注册、封装到系统中;
步骤5,算法加载:根据业务流程在系统中组装需要的组件;基于多线程和XML配置,系统可对所述组件进行加载控制;根据执行方式的不同将执行线程池分为实时交互线程池和自动作业线程池,并根据具体的人机交互和自动作业的需求对所述实时交互线程池和自动作业线程池的线程个数的比例关系进行调整。
步骤6,算法执行:采用Java RMI远程调用技术发布框架,将所述组件以服务的方式对外发布,供人机交互Web服务层调用执行;执行过程中,对输入输出参数进行赋值,计算完成后输出结果,结束一个完整算法的使用流程。
优选的,在将所述气候算法的算法实体注册到系统中后,还可以进一步对气候算法的算法实体进行算法替换、算法修改以及算法共享。
至此,本领域技术人员应认识到,虽然本文已详尽示出和描述了本发明的多个示例性实施例,但是,在不脱离本发明精神和范围的情况下,仍可根据本发明公开的内容直接确定或推导出符合本发明原理的许多其他变型或修改。因此,本发明的范围应被理解和认定为覆盖了所有这些其他变型或修改。

Claims (10)

1.一种基于组件服务的众创性气候算法管理系统,其特征在于包括算法配置数据库、算法编译模块、算法校验模块、算法注册模块、算法加载模块以及算法执行模块;
所述算法配置数据库含有气候算法的算法实体、算法配置信息以及输入输出规范;所述算法配置信息包括气候算法的元数据信息以及气候算法的输入输出参数;
所述算法编译模块用于对气候算法的算法实体进行编译;
所述算法校验模块用于校验气候算法的输入输出参数是否符合输入输出规范;
所述算法注册模块用于对所述气候算法的算法实体进行注册、封装,在Java Spring框架下编写Java调用代码实现对气候算法的算法实体的调用,然后利用Spring自定义标签技术及Spring依赖注入技术将算法配置信息及气候算法的算法实体注册到系统中;
所述算法加载模块用于根据业务流程组装需要的组件,并基于多线程和XML配置实现对所述组件的加载控制;
所述算法执行模块用于气候算法的算法实体的调用执行;所述算法执行模块采用JavaRMI远程调用技术发布框架,将所述组件以服务的方式对外发布,供人机交互Web服务层调用执行。
2.如权利要求1所述基于组件服务的众创性气候算法管理系统,其特征在于:所述气候算法的算法实体的编写语言为NCL语言、Java语言、Fortran语言、Python语言或Grads语言。
3.如权利要求1所述基于组件服务的众创性气候算法管理系统,其特征在于:所述气候算法的算法实体的编写语言为脚本语言,当编写语言为脚本语言时,不需要对气候算法的算法实体再进行编译。
4.如权利要求1所述基于组件服务的众创性气候算法管理系统,其特征在于:所述算法加载模块可根据执行方式的不同将执行线程池分为实时交互线程池和自动作业线程池,并根据具体的人机交互和自动作业的需求对所述实时交互线程池和自动作业线程池的线程个数的比例关系进行调整。
5.如权利要求1所述基于组件服务的众创性气候算法管理系统,其特征在于还包括算法替换、修改与共享模块,用于在气候算法注册、封装后对气候算法的算法实体进行算法替换、算法修改以及算法共享。
6.一种基于组件服务的众创性气候算法管理方法,其特征在于包括以下步骤:
步骤1,建立算法配置数据库:在系统中建立算法配置数据库,将气候算法的算法实体、算法配置信息以及输入输出规范输入算法配置数据库;所述算法配置信息包括气候算法的元数据信息以及气候算法的输入输出参数;
步骤2,算法编译:在编译器中对气候算法的算法实体进行编译;
步骤3,算法校验:系统对所述气候算法的输入输出参数是否符合输入输出规范进行校验,如果符合输入输出规范,则进行步骤4;如果不符合输入输出规范,则需要修改后重新进行步骤2;
步骤4,算法注册:在Java Spring框架下编写Java调用代码实现对气候算法的算法实体的调用,然后利用Spring自定义标签技术及Spring依赖注入技术将算法配置信息及气候算法的算法实体注册到系统中;
步骤5,算法加载:根据业务流程在系统中组装需要的组件;基于多线程和XML配置,系统可对所述组件进行加载控制;
步骤6,算法执行:采用Java RMI远程调用技术发布框架,将所述组件以服务的方式对外发布,供人机交互Web服务层调用执行。
7.如权利要求1所述基于组件服务的众创性气候算法管理方法,其特征在于:所述气候算法的算法实体的编写语言为NCL语言、Java语言、Fortran语言、Python语言或Grads语言。
8.如权利要求1所述基于组件服务的众创性气候算法管理方法,其特征在于:所述气候算法的算法实体的编写语言为脚本语言,并跳过步骤2,直接进行步骤3。
9.如权利要求1所述基于组件服务的众创性气候算法管理方法,其特征在于:所述步骤5,算法加载中,根据执行方式的不同将执行线程池分为实时交互线程池和自动作业线程池,并根据具体的人机交互和自动作业的需求对所述实时交互线程池和自动作业线程池的线程个数的比例关系进行调整。
10.如权利要求1所述基于组件服务的众创性气候算法管理方法,其特征在于还包括以下步骤:
算法替换、修改与共享:所述气候算法注册到系统中后,还可以对气候算法的算法实体进行算法替换、算法修改以及算法共享。
CN201810448353.6A 2018-05-11 2018-05-11 基于组件服务的众创性气候算法管理系统及方法 Active CN108681446B8 (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201810448353.6A CN108681446B8 (zh) 2018-05-11 2018-05-11 基于组件服务的众创性气候算法管理系统及方法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201810448353.6A CN108681446B8 (zh) 2018-05-11 2018-05-11 基于组件服务的众创性气候算法管理系统及方法

Publications (3)

Publication Number Publication Date
CN108681446A true CN108681446A (zh) 2018-10-19
CN108681446B CN108681446B (zh) 2021-05-14
CN108681446B8 CN108681446B8 (zh) 2021-07-23

Family

ID=63806223

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201810448353.6A Active CN108681446B8 (zh) 2018-05-11 2018-05-11 基于组件服务的众创性气候算法管理系统及方法

Country Status (1)

Country Link
CN (1) CN108681446B8 (zh)

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110298781A (zh) * 2019-07-04 2019-10-01 南京恩瑞特实业有限公司 基于WebGL的气象雷达及卫星大数据可视化方法
CN112596853A (zh) * 2020-12-08 2021-04-02 青岛积成电子股份有限公司 一种实现可拔插式人工智能可视化的方法
CN113138771A (zh) * 2020-01-17 2021-07-20 北京达佳互联信息技术有限公司 数据处理方法、装置、设备及存储介质
CN113377465A (zh) * 2021-06-07 2021-09-10 上海商汤智能科技有限公司 基于服务的sdk调用方法及装置、电子设备和存储介质

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20120016654A1 (en) * 2007-06-15 2012-01-19 The Mathworks, Inc. Bi-directional projection
CN105446730A (zh) * 2015-01-21 2016-03-30 胡宝清 一种资源环境模型库构建方法
CN107451663A (zh) * 2017-07-06 2017-12-08 阿里巴巴集团控股有限公司 算法组件化、基于算法组件建模方法、装置以及电子设备

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20120016654A1 (en) * 2007-06-15 2012-01-19 The Mathworks, Inc. Bi-directional projection
CN105446730A (zh) * 2015-01-21 2016-03-30 胡宝清 一种资源环境模型库构建方法
CN107451663A (zh) * 2017-07-06 2017-12-08 阿里巴巴集团控股有限公司 算法组件化、基于算法组件建模方法、装置以及电子设备

Non-Patent Citations (2)

* Cited by examiner, † Cited by third party
Title
KARSTEN WEIHE: "A Software Engineering Perspective on Algorithmics", 《ACM COMPUTING SURVEYS》 *
刘钊等: "聚类算法组件构建的分析与研究", 《微计算机信息》 *

Cited By (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN110298781A (zh) * 2019-07-04 2019-10-01 南京恩瑞特实业有限公司 基于WebGL的气象雷达及卫星大数据可视化方法
CN113138771A (zh) * 2020-01-17 2021-07-20 北京达佳互联信息技术有限公司 数据处理方法、装置、设备及存储介质
CN112596853A (zh) * 2020-12-08 2021-04-02 青岛积成电子股份有限公司 一种实现可拔插式人工智能可视化的方法
CN113377465A (zh) * 2021-06-07 2021-09-10 上海商汤智能科技有限公司 基于服务的sdk调用方法及装置、电子设备和存储介质

Also Published As

Publication number Publication date
CN108681446B8 (zh) 2021-07-23
CN108681446B (zh) 2021-05-14

Similar Documents

Publication Publication Date Title
CN108681446A (zh) 基于组件服务的众创性气候算法管理系统及方法
CN112394922B (zh) 决策配置方法、业务决策方法和决策引擎系统
CN103441900B (zh) 集中式跨平台自动化测试系统及其控制方法
US8359566B2 (en) Software factory
US20150142949A1 (en) System and method for collaborative designing, development, deployment, execution, monitoring and maintenance of enterprise applications
EP2455859B1 (en) Model-based programming, configuration, and integration of networked embedded devices for use in wireless sensor networks
US20100121740A1 (en) Data driven orchestration of business processes
US20090300586A1 (en) Staged automated validation of work packets inputs and deliverables in a software factory
US20080256505A1 (en) Rapid On-Boarding of a Software Factory
US20100122232A1 (en) Reusable business sub-processes and run-time assembly
CN102375731A (zh) 一种免编码集成应用软件平台系统
CN101589366A (zh) 面向生成器图形的编程框架中的并行化和植入
CN110428054A (zh) 基于编译技术的业务规则引擎模式匹配系统及实现方法
CN102799962A (zh) 一种配置型业务流程系统及其实现方法
Kobayashi et al. Need-based requirements change management
KR102237167B1 (ko) 변환 생성용 시스템
CN101188012A (zh) 一种交易数据的清算系统及清算方法
Schäffer et al. Configuration based process and knowledge management by structuring the software landscape of global operating industrial enterprises with Microservices
Redding et al. Transforming object-oriented models to process-oriented models
CN105739980A (zh) 业务的统一开发方法和设备
CN103617513A (zh) 一种支持规则演化的计算流引擎方法
CN103544154A (zh) 一种数据格式转换的方法
CN105975381B (zh) 故障监测专家系统集成开发平台
Heiskala et al. A conceptual model for configurable services
CN110633077B (zh) 一种基于模块化的快速开发系统及方法

Legal Events

Date Code Title Description
PB01 Publication
PB01 Publication
SE01 Entry into force of request for substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant
CI03 Correction of invention patent

Correction item: Patentee|Address|Patentee

Correct: NATIONAL CLIMATE CENTER|100000 No. 46, Zhongguancun South Street, Haidian District, Beijing|NANJING NRIET INDUSTRIAL Co.,Ltd.

False: NATIONAL METEOROLOGICAL CENTER|100000 No. 46, Zhongguancun South Street, Haidian District, Beijing|NANJING NRIET INDUSTRIAL Co.,Ltd.

Number: 20-02

Page: The title page

Volume: 37

Correction item: Patentee|Address|Patentee

Correct: NATIONAL CLIMATE CENTER|100000 No. 46, Zhongguancun South Street, Haidian District, Beijing|NANJING NRIET INDUSTRIAL Co.,Ltd.

False: NATIONAL METEOROLOGICAL CENTER|100000 No. 46, Zhongguancun South Street, Haidian District, Beijing|NANJING NRIET INDUSTRIAL Co.,Ltd.

Number: 20-02

Volume: 37

CI03 Correction of invention patent