System and method for developing and processing building system control solutions
A method for processing an application includes obtaining a list of point types used as inputs for an application from an application definition. In some cases, the application is configured to perform a function pertaining to an environmental control system of a building. The method also includes mapping each point type to an actual control system point name defined in a configuration file. The method further includes retrieving data for the actual control system point names from a database for processing by the application.
This is a divisional of U.S. patent application Ser. No. 10/668,049, filed Sep. 23, 2003, which in turn claims the benefit of U.S. Provisional Patent Application Ser. No. 60/441,838, filed Jan. 22, 2003, both of which are incorporated herein by reference.
This Application is related to U.S. patent application Ser. Nos. 10/629,226 filed Jul. 28, 2003; Ser. No. 10/628,977 filed Jul. 28, 2003; Ser. No. 10/629,976 filed Jul. 28, 2003; Ser. No. 10/629,229 filed Jul. 28, 2003 and 10/628,978 filed Jul. 28, 2003.
FIELD OF THE INVENTIONThis invention relates to control systems for building systems such as environmental systems and, more particularly, to systems for developing and processing control applications for building systems.
BACKGROUND OF THE INVENTIONMost commercial properties include a number of building systems that monitor and regulate various functions of the building for the comfort and well-being of the tenants. These building systems include security systems, fire control systems, and elevator systems. One prevalent and important building system is the environmental control system.
An environmental control system is used to regulate the temperature and flow of air throughout a building. The air conditioning for a building typically includes one or more chillers for cooling air and one or more heaters for warming air. Fans distribute air conditioned by a chiller or heater into a duct system that directs the flow of air to the various rooms of a building. Dampers are located within the duct system to variably control an opening to a branch of a duct system or to a room. The dampers are maneuvered through a range of movement from being 100% open to 0% open, i.e., closed, by actuators. Also, the speed of a motor that drives a fan is controlled to regulate fan speed and, correspondingly, air flow in the system. An important component of a building environmental system is the control system that varies the fan motor speed and the position of the various dampers to maintain pressure and flow rate set points for the system.
Control systems for building systems are increasingly reliant upon computer and network technology. Micro-controllers and the like may be used to operate and maintain actuators for damper position as well as controlling fan speed. These local controllers provide operational data to an overall system controller. The overall system controller is typically a computer that analyzes data received from local controllers to determine whether system parameters, such as set points, are being maintained. If the system parameters are not being met, the system controller issues command messages to one or more local controllers to adjust local control so the system parameters may be achieved. In some previously known systems, the system controller communicates with the local controllers over a computer network. Most typically, the hardware platform for the network is an Ethernet platform and the network software supporting communication over the network is a TCP/IP layer. This structure supports communication between a control application program executing on the system controller and an application program executing on the local controller. However, the computer network does not provide remote building system engineers with access to the application programs.
In order to monitor a building system, a system controller typically receives status data from local controllers periodically or as conditions change. These data may be analyzed by the system controller to determine whether commands for local controllers should be generated and then discarded or stored after being analyzed. These stored data may be characterized as historical data for the building system. These historical data may be very useful for determining response characteristics of a building system or for other system modeling uses. However, these historical data are typically stored at the building site. Consequently, these data are inaccessible to building system engineers unless a copy of these data are generated and migrated to another location for analysis and modeling purposes. Additionally, previously known systems require the system controller to store the operational data in a database. Thus, the system controller absorbs an administrative overhead for managing the storage of operational data in a local database. This administrative overhead may include programming logic to convert data values to a common format or to manipulate the application programming interface (API) of a database.
In an effort to reduce this administrative overhead, systems have been developed that segregate the informational aspects of a building control system from the control aspects. For example, U.S. Pat. No. 6,141,595 discloses a system that includes an information layer and a control layer that interface with a group of databases. The control layer enables control applications to access attribute data for the purpose of operating control devices in a building. Optimization applications update the control attributes for improved control of the building system. The information layer supports communication with applications through the Internet or other network interfaces so external users may access the data in the databases. The control and optimization applications, on the other hand, query the databases through their respective APIs. Thus, control and optimization application developers need to be able to program the access methods for the various databases into their applications. The control layer provides a standardized interface for the control and optimization applications to the components of the building system.
While the system of the '595 patent separates external user communication with the databases from the control and optimization application communication with the databases, it still requires the control and optimization application developers to program database access methods in the applications. Consequently, the building engineers are required to be knowledgeable regarding a variety of database APIs. Furthermore, the control and optimization applications are not readily accessible to the external users. Also, the system of the '595 patent assumes that the control and optimization applications are tested and fully developed before being installed between the control layer and the system database APIS. However, the system of the '595 patent does not provide an environment for accessing data to model and to test an application before being installed on the system.
In addition to the data limitations of previously known systems, there are other issues that compound the problem of developing applications for building systems. Typically, companies that manage buildings have to somehow obtain the programs for controlling a building system from an outside source. Otherwise, the building manager would need to keep a team of system engineers and programmers for application development. The system engineers understand the building system components and develop control algorithms and load predictors for control of the system. However, they typically do not have adequate knowledge of software methodologies and programming techniques to generate and test computer programs efficiently. Likewise, the computer programmers and software engineers are able to design, develop, test, and integrate computer programs but they do not possess the building system expertise to appropriately apply control theory to building system components. Typically, however, companies that manage building systems do not have sufficient resources to support a team of system engineers and software engineers. Accordingly, they employ a staff of technicians to maintain and operate the building system components and seek to obtain the application solutions for their system needs from outside sources.
One way in which building management companies may seek to obtain application solutions is to purchase general purpose control programs for systems comprised of components similar to the ones in a particular building system. However, no such general purpose solution exists as the uniqueness of building system topology, component composition, and other factors make it impracticable to develop and adapt a general solution for most building system needs efficiently.
Another way to obtain application solutions is to procure the services of an building system engineering service. Typically, these companies employ both building system engineers and computer engineers for developing and testing application solutions for building systems that are owned and operated by one or more building management companies. The obstacles to the development and testing of application solutions for different building systems are significant. For one, building systems use different types of controllers, actuators, and networks for communicating between building system components. As a result, the computer engineers need to be able to write programs in a variety of control program languages and implement controls for and obtain data from a plethora of devices that require commands and supply data in different formats. Additionally, the computer engineers must be able to work with system engineers to convert the control algorithms and load predictors designed by the system engineers into computer software. This human interface may require an extensive amount of time and significant expenditure of resources to take a building system solution from its system design to implementation in a building system. This expenditure is especially exacerbated when, for example, system engineers who specialize in load prediction and system engineers who specialize in HVAC systems both need to have their designs implemented by the same computer engineering team for a building system. This need puts pressure on the computer engineering team to develop expertise for writing software in different operational fields without proven expertise in each of those fields.
One way that a computer engineering team meets these types of needs is to obtain various software packages from software vendors and then adapt them for implementing a piece of an application solution. For example, a neural network package may be purchased and adapted to implement a load forecasting component of a building system solution. Another package that may be required is a data base management system for storing and querying data required for application solution support. Other packages may include data computational programs for various building system parameters and other engineering tools for particular building systems. However, one problem with this approach is the need to integrate disparate packages that may be programmed in different languages operating on different platforms. Latency and data compatibility issues may arise during the integration efforts.
What is needed is a system for facilitating the development of application solutions with reduced compatibility issues.
What is needed is a system for developing application solutions that does not require implementation of solution components in a variety of computer languages.
What is needed is a system for reducing the need for human interaction in translating a system engineering design into an operational solution.
What is needed is a system that provides support for diverse fields of operational expertise.
What is needed is a system for developing control applications without requiring knowledge of a database API being programmed into the application.
What is needed is a system for developing control applications that permit the real-time and historical data for a building system to be used for application modeling and testing without requiring the installation of the application in the system.
What is needed is a way to enable external users to access applications.
SUMMARY OF THE INVENTIONAt least some of the above limitations of previously known systems and methods may be overcome by a system and method implemented in accordance with one or more embodiments of the present invention. Some embodiments include a systems design verifier and a system design converter for converting a verified system design into an application solution. The systems design verifier is configured to receive a system design, preferably written in a language for describing a system and control logic for the system. The language is selected as being familiar to system engineers for identifying system components and requirements. For example, XML files may be used to identify HVAC components and the duct layout in a system. Verification of a system design includes checking the syntax of the system description and logic. The system design converter generates computer program statements for components in the building system to implement the system design.
Embodiments of the present invention may also include a tool interface for coupling to the system design converter so that the design converter may generate computer program statements for use of a computer tool. These computer tools include data organization tools, such as data base management systems, data filtering tools, statistical analysis packages, and analytical methods, such as linear programming modules. The design converter generates the computer programming statements for manipulating the interface to a computer tool to pass data to a tool for the generation and return of data. For example, the design converter may provide variable values for a set of equations and a forcing vector to a linear programming tool and receive a set of equation coefficients. The system may also include an interface for external computer program modules that may be included in the application solution. For example, a proportional-integral-derivation control loop module may be accessed through the external program interface.
The embodiments of the present invention that include the interfaces for computer tools and external programs enables the system design converter to convert a system design into computer program statements that may be executed by one or more components of a building system. The tools interface enables the design converter to obtain data for incorporation in the program being generated by the converter and the external program interface permits the design converter to include statements for using external programs in the program being generated. These interfaces also provide testing support for a generated program. Once tested, the generated program may be stored in a file for transmission or other transfer to a building site for installation in one or more components of the building system.
Some embodiments of the present invention enable system engineers to design building system control logic that is converted into a computer program without requiring the system engineers to communicate system design expertise to software engineers or to write computer programs. Likewise, the computer engineers are able to focus on selecting computer tools and external programs that may be used to support application solution development and then programming the interfaces to make the tools and external programs accessible to the programs generated by the converter. The system design converter, tools interface, and external program interface comprise an application infrastructure.
A first embodiment is a system that includes a database, a data provider interface for converting between a common database access method and a database application programming interface (API), and an application infrastructure for coupling an application program to the data provider interface so that an application having common database access method instructions may access the database through the data provider interface. The application infrastructure of the present invention provides an interface to the data provider that does not require the system engineer to provide database instructions that conform to the API for the database. Instead, the data provider converts the common database access method instructions of the system design program to access method instructions that conform to the API for the database. Likewise, the responses from the database received by the data provider through the database API are converted into responses compatible with the common database access method instructions so the application may receive the requested data. The infrastructure and data provider interface of this embodiment are especially advantageous when the database is comprised of a plurality of databases with each database having a different database API. This interface structure enables, for example, a historical database, or data mart, to have a different structure and interface that better supports data mining than a real-time database interface. For example, the data mart may use a star or snowflake data organization to facilitate data mining while the real-time database retains a more conventional Standard Query Language (SQL) interface. The application infrastructure allows the application programmer to develop an application without requiring knowledge of the two database structures and their particular APIs. Consequently, a building system control application developer may concentrate on those aspects of an application that provide efficient control over the building parameters affected by the application.
The application infrastructure of the present invention may also include Web-based components for coupling application solutions to the Internet or other computer networks that use the TCP/IP or other communication schema of the Internet. Again, the system engineer need not be proficient in the details of the implementation of the network access. Instead, the engineer defines the application as requiring Web-based communication and an appropriate Web-based interface component is provided so the application and/or its output may be accessed over the Internet or other computer network. Preferably, the application infrastructure also includes Windows-based components for communicating with other applications that run under a version of the Windows operating system. Again, the engineer need not be proficient in the application-to-application communication techniques under the Windows system as the Windows-based components provide that communication interface through a more generic interface through which the applications may be coupled.
The above-described architecture of the present invention enables system engineers to develop application programs without requiring the engineers to know the subtleties and nuances of specific database APIs and communication protocols. Instead, the engineers may focus on the engineering requirements of the building system being controlled by the application and the effects of the control actions of the application. This segregation of the communication and database access components into the application infrastructure and data provider interface empower building system engineers to generate application solutions more efficiently. Furthermore, the Web-based components may be used to make the applications available to users through a customer web portal (CWP). The CWP enables the applications to be developed by a service organization at a common site where the database is maintained so the applications may be developed and tested with a wide variety of data. The applications once tested and verified as being field ready, may be downloaded through the CWP to a particular building site and installed as an application for execution by a system controller or local controller in the building system. Also, the CWP may be used by external users to access reports or other summaries that may be generated by applications operating on the data mart. This Web access enables data mining applications and the historical database to be maintained at a common site rather than requiring every building site to have its own database and data mining applications.
An embodiment of the system of the present invention may also include a configuration data utility for developing a system design program representative of a building system and associating configuration data with the components identified in the file structure generated by the configuration utility. Preferably, the configuration data utility uses Extended Markup Language (XML) to organize the components of a building system in a file/folder structure. The utility also associates configuration data, such as that related to devices and sensors, with component folders in the XML structure. This utility enables an application program to traverse the file/folder structure to obtain and to process data for building system components.
An embodiment of the system of the present invention may also include a data collector interface for coupling external data sources to the database. The data collector interface converts data from the native format for an external data source to one that is compatible with the structure of the database in which the data is stored. This data conversion function of the data collector interface enables the database or databases of the present invention to be coupled to a plurality of external data sources without requiring that all of the external data sources conform to one particular database structure. Furthermore, the data collector interface includes transaction services that generate the instructions for a database API that are required to store the data in the database. Thus, data sources from diverse locations may be coupled to a database at a common site. Consequently, a significant accumulation of historical data may be obtained for a data mart component of the database, which further enhances the value of the data mining applications at the common site. However, the data provider interface also supports the segregation of the collected data into different databases so control application programs may be developed from the data originated at the particular building site for which the application is being developed.
Other embodiments of the system of the present invention may also include a scheduling service that may be coupled to the application programs and the data collector interface. In accordance with schedule data, the scheduling service activates data collector interface components to interrogate external data sources for data that may then be converted for storage in the database or data mart component maintained at the common site. In this manner, the database and data mart are automatically updated. In a similar manner, the scheduling service activates application programs for operating on the data stored in the database and/or data mart component to generate reports that may be accessed through the CWP or Windows-based communication methods. Thus, the system of the present invention not only facilitates the development of application programs for building systems but it enables remote users to obtain timely analysis of the data from a building system without the need to maintain application programs or a database at a building site.
An exemplary embodiment of an inventive method includes verifying an application definition to identify data for implementing in the application defined by the application definition and converting the identified data into computer program statements. The computer data conversion includes program statements using computer tools and external programs. The definition verification includes verifying the syntax of the application definition.
The application data conversion may include converting common database access method instructions into database API queries, and converting the responses to the database API queries into common database access method responses. The application data conversion for data base access enables application programs to have a common interface to a database or databases without requiring the system engineer to provide database instructions that conform to the API for the database. Instead, the data provider of a tool interface converts the common database instructions of an application definition to an access method that conforms to the API for the database. Likewise, the responses from the database through the database API are converted into the common database instructions so the application may receive requested data. The conversion of this embodiment is especially advantageous when the database is comprised of a plurality of databases with each database having a different database API. The conversion allows a system engineer to develop an application without requiring knowledge of the two database structures and their particular access interfaces. Consequently, a building system control application developer may concentrate on those aspects of the application that provide efficient control over the building parameters affected by the application.
The data identification may be comprised of obtaining a list of point types that are used as inputs for the application and mapping each point type to an actual control system point name. Preferably, the control system point names are contained in a configuration data file compiled by a configuration data utility. The actual control system point names are used to generate the API queries for retrieving data from a database for the application. The application definition may be verified to identify common calculation components that may be used to generate outputs for the application. The outputs of the application may be delivered to external users through the CWP or stored in the database through the data provider.
The delivery through CWP may also include identifying Web-based components that are coupled to an application communication over the Internet or other computer network. Again, an application developer need not be proficient in the details of the implementation of the network access. Instead, Web-based components transparently communicate data over the Internet or other computer network. Delivery to another Windows application, preferably, includes identifying Windows-based components that are coupled to an application for communication between applications running under a version of the Windows operating system. Again, the application programmer need not be proficient in the application-to-application communication techniques under the Windows system as the Windows-based components provide that communication interface through a more generic interface through which the applications may be coupled.
The output of an application may include an application or a group of set points that may be delivered to an external application through the CWP. The CWP enables the applications to be developed by a service organization at a common site where the database is maintained so the applications may be developed and tested with a wide variety of data. The applications once tested and verified as being field ready, may be downloaded through the CWP to a particular building site and installed as an application executed by a system controller or local controller in the building system. Also, the CWP may be used by external users to access reports or other summaries that may be generated by applications operating on the data mart. This Web access enables data mining applications and the historical database to be maintained at a common site rather than requiring every building site to have its own database and data mining applications.
The configuration data files may be developed as structures with file and folder names that correspond to building system components having associated data that identify the contexts of the components. Preferably, the file and folder structures are developed using Extended Markup Language (XML) to organize the components of a building system. The context data includes manufacturer data, engineering units, location data, and other building system data. These data enable an application program to traverse a configuration data file to obtain data for building system components so building system control applications may be tested.
Embodiments of the method of the present invention may also include determining an activity is scheduled for execution and activating the activity. The activity may include obtaining data from an external data source and converting the data so the data are compatible with a database in which the data are stored. This source data conversion enables the database or databases of the present invention to be coupled to a plurality of external data sources without requiring that all of the external data sources conform to one particular database structure or representative schema. Furthermore, the data conversion enables data sources from different building sites to be coupled to a database at a common site. Consequently, a significant accumulation of historical data may be obtained for the data mart, which further enhances the value of the data mining applications at the common site. However, the source data conversion also supports the segregation of the collected data into different databases so control application programs may be developed from the data originated at the particular building site for which the application is being developed.
Activities that may be activated by scheduling include application programs for operating on data stored in a database and/or data mart to generate reports that may be accessed through the CWP or Windows-based communication methods. As previously noted, the scheduling may also include activating interrogation of external data sources for data so the data may be converted for storage in the database or data mart maintained at the common site. In this manner, the database and data mart are automatically updated. Thus, the method of the present invention not only facilitates the development of application programs for building systems but it enables remote users to obtain timely analysis of the data from a building system without the need to maintain application programs or a database at the building system site.
The system and method of at least some embodiments of the present invention facilitates development of application solutions with reduced compatibility issues.
The system and method of at least some embodiments of the present invention do not require implementation of solution components in a variety of computer languages.
The system and method of at least some embodiments of the present invention reduce the need for human interaction in translating a system engineering design into an operational solution.
The system and method of at least some embodiments of the present invention provide support for diverse fields of operational expertise.
The system and method of at least some embodiments of the present invention enable the development of control applications without requiring knowledge of a database API being programmed into the application.
The system and method of at least some embodiments of the present invention permit real-time and historical data for a building system to be used for application development without requiring the installation of the application in a particular building system controller.
The system and method of at least some embodiments of the present invention provides a mechanism that enables external users to access applications.
The system and method of at least some embodiments of the present invention provide database access for application programs that does not require database API programming.
These and other advantages and features of at least some embodiments of the present invention may be discerned from reviewing the accompanying drawings and the detailed description of the invention.
BRIEF DESCRIPTION OF THE DRAWINGSThe present invention may take form in various components and arrangement of components and in various methods. The drawings are only for purposes of illustrating exemplary embodiments and alternatives and are not to be construed as limiting the invention.
A system 10 incorporating the principles of the present invention is shown in
Application solutions 14 execute on a computer having sufficient resources to support the applications as well as web-based components 38 and Windows-based components 40. For example, a computer system having at least a Pentium 4 processor operating at 1.8 GHz with 128 MB of RAM and a 60 GB hard drive is required for application space execution. The operating system of the computer may be used to provide security for applications 14. For example, the Windows operating system may be used to check user names, verify passwords, provide encryption, and control other access paths for activating applications. This security is available for those users who connect to the operating system of the computer and attempt to log on the computer. Applications 14 may also participate in system security by verifying user authorization to execute an application, by not storing unencrypted passwords, and by using secure procedures for accessing database 18. Likewise, file and folder permissions may be set to restrict user access to specific folders and files for application activation and data.
Web-based components 38 may communicate with users external to the site where the applications are executing. For these users, CWP 48 also requires security/authentication functions. Preferably, this security is supported by a lightweight directory access protocol (LDAP) database and a single sign-on may be used to allow access to applications that may be activated by users over the Internet. Single sign-on may be used to permit users to switch between applications without having to logoff and log on again.
Infrastructure 34 is shown in more detail in
Interfaces 60 and 62 are common interfaces that convert statements from converter 58 that are in a common tool interface format or a common external program interface format. Interfaces 60 and 62 may be interactive for querying a user of converter 58 for data that may be used to activate a tool or external program. For example, a set of modeling equations described in the application definition may use historical data in a data base that may be accessed through computer tool interface 60. The modeled responses may be obtained from a linear programming external module coupled to converter 58 through interface 62. Examples of computer tools that may be accessed through computer tool interface 60 include data organization tools, such as data base management systems, data filtering tools, statistical analysis packages, and analytical methods, such as linear programming models. External programs that may be accessed through external program module interface 62 may include, for example, proportional-integral-derivative control loop modules and other modular computer program components. The components coupled to the system design converter may be a web-based component 38, a Windows-based component 40, or a common component 44. Thus, infrastructure 34 enables a system engineer to define an algorithm and system structure that may be converted into an application solution for a building system. System design converter 58 uses data derived from computer tools that are accessed through computer tools interface 60 and incorporates external program modules that are obtained through external program interface 62. Consequently, the system engineer is not required to be able to program in the control language of the building system components nor does the engineer need to know how to manipulate the computer tools or to select the external program modules. Instead, the components of infrastructure 34 perform these tasks for the engineer automatically.
As shown in
Database 18 may be comprised of more than one database and each database may be managed by its own database management system (DBMS). Each DBMS communicates with data provider 20, which is part of interface 60, to provide data to application 30a-30n. Data provider 20 may execute on a computer having a Pentium 4 processor operating at 1.8 GHz with 128 MB of RAM and 60 GB of hard drive storage. A DBMS for any of the database(s) of database 18 may be any known DBMS. Data provider services 20 act as a software wrapper for database 18 and provide common business logic for the applications accessing database 18. Data provider 20 receives database instructions from applications 30a-30n that conform to a common database access method instruction format and converts them into database queries that conform to the API for the particular database within database 18 that the application is attempting to access. The API responses to the queries are received by data provider services 20, converted to the common database language form, and returned to applications 14. Thus, data provider services handle the API specifics for communicating with a database within database 18. This permits the application programmer to view all of the databases as having a homogeneous structure that may be accessed by the same access methods.
A business logic model that may be supported by data provider 20 is shown in
In the model shown in
Activity 70 and schedule 74 data may be used to activate an activity at a particular time. Preferably, activity 70 includes backing up one or more field panels, restoring one or more field panels, generating a report, activating an application, or invoking discovery to obtain data for a particular BLN. This preferred list of activities is merely exemplary and other activities may be identified and stored within the model shown in
Database 18 may also include a data mart component. A data mart is comprised of pre-constructed data for interactive use with an application 30a-30n for report and analysis purposes. These data are typically obtained from cleansing, refining, transforming, calculating, and deriving new measures from raw data stored in database 18. The segregation of data for report and analysis purposes from the real-time components of database 18 reduces the risk of performance problems arising from transaction service interaction with the real-time components of database 18. The data mart component may be constructed according to a star or snowflake configuration as this data model is more conducive to report generation or data mining applications. Preferably, data from a data collector service 114 is provided by a transaction service 118 to a SQL Server 200 Replication Service 150 which may be part of the implementation of database 18 (
With reference to
Transaction services 118 receive data in a common data format from data collector services 114 and provide the data to data provider 20 for populating the data structures of database 18. Each transaction service of transaction services 118 uses the common database instructions for communicating data with data provider 20, which provides the data through the API of the appropriate database component of database 18 in which the data is to be stored.
Data collector services 114,
As shown in
Using like numerals for like components, system 10 may be depicted as shown in
Preferably, configuration data file 164 is implemented in XML. XML is supported by a wide variety of software vendors and users may define the tags in XML that describe data content. In the present invention, generic tag names, such as site, building, plant, cooling plant, and heating plant, may be used to represent location and group contexts. Generic names, such as circuit, bank, branch, inlet, outlet, supply, discharge, return, actual, and setpoint, may be used to represent system configurations and functions. Equipment type identifiers, such as condenser, compressor, chiller, evaporator, pump, and fan, may be used to represent equipment contexts. Identifiers, such as temperature, pressure, relative humidity, flow, and air change, may be used to represent sensor types. Generic element names, such as air, water, glycol, refrigerant, power, and energy, may be used to identify media in a system. Generic attributes, such as volume and capacity, may be used to identify nameplate data and design information. As noted above, parent-child relationships in the database may be used to identify equipment group relationships.
A screen of a representative system depicting the exemplary XML implementation of a configuration data file is shown in
Common components 44 (
An exemplary method for processing application definitions is shown in
The structure of wrapping database 18 in a data provider 20 relieves a building system application programmer from having to program logic for database access. Likewise, manipulation of configuration data files, database access, web communication, or operating system communication, may be performed by common components within application infrastructure 34. This enables an application programmer to program logic for building system control and engineering without having to learn and provide logic for database API interaction or computer network communication. Likewise, database 18 may be updated and maintained by activities associated with building system structure that may be activated on a scheduled basis. Again, data provider 20 converts native mode data into a common format for storage in database 18 so data collector services do not have to contain database API logic. Thus, the architecture of system 10 supports the development of application solutions in an environment that does not require database and computer communication programming knowledge and that supports delivery of the applications or their outputs to external users over the Internet.
While the present invention has been illustrated by the description of exemplary processes and system components, and while the various processes and components have been described in considerable detail, applicants do not intend to restrict or in any limit the scope of the appended claims to such detail. Additional advantages and modifications will also readily appear to those skilled in the art. The invention in its broadest aspects is therefore not limited to the specific details, implementations, or illustrative examples shown and described. Accordingly, departures may be made from such details without departing from the spirit or scope of applicants' general inventive concept.
Claims
1. A method for processing an application comprising:
- a) obtaining a list of point types used as inputs for an application from an application definition;
- b) mapping each point type to an actual control system point name defined in a configuration file; and
- c) retrieving data for the actual control system point names from a database for processing by the application.
2. The method of claim 1, wherein step c) further comprises:
- converting common database access instructions in the application to database access instructions for the database API; and
- converting responses from the database API to common database access responses for application processing.
3. The method of claim 2, further comprising:
- d) generating outputs from the converted responses; and
- e) delivering the outputs to a user.
4. The method of claim 3, wherein step e) further comprises:
- posting the outputs for retrieval at a customer web portal.
5. The method of claim 3, wherein step e) further comprises storing the outputs in the database.
6. The method of claim 1, wherein step c) further comprises retrieving data via a data provider interface, the data provider interface operable to convert between common database access method instructions and other database access instructions.
7. The method of claim 1, further comprising:
- d) retrieving data from a data mart for processing by the application, the data mart including information previously processed from data obtained from the database.
8. A method for processing an application comprising:
- a) providing a configuration file identifying a plurality of actual control system point names, the actual control system point names corresponding to points in a building control system, said points including sensor point identifiers;
- b) obtaining a list of point types used as inputs for an application from an application definition;
- c) mapping each point type to an actual control system point name defined in a configuration file; and
- d) retrieving data for the actual control system point names from a database for processing by the application.
9. The method of claim 8, wherein step d) further comprises retrieving data via a data provider interface, the data provider interface operable to convert between common database access method instructions and other database access instructions.
10. The method of claim 8, wherein step a) further comprises providing the configuration file in XML data format.
11. The method of claim 8, further comprising:
- e) retrieving data from a data mart for processing by the application, the data mart including information previously processed from data obtained from the database.
12. The method of claim 11, wherein the database and the data mart are accessible via a data provider interface, the data provider interface operable to convert between common database access method instructions and other database access instructions.
13. The method of claim 8, further comprising:
- e) generating outputs based on the retrieved data; and
- f) delivering the outputs to a user.
14. The method of claim 13, wherein step f) further comprises:
- posting the outputs for retrieval at a customer web portal.
15. The method of claim 14, wherein step f) further comprises storing the outputs in the database.
16. A method for processing an application comprising:
- a) obtaining a list of point types used as inputs for an application from an application definition, the application configured to perform a function pertaining to an environmental control system of a building;
- b) mapping each point type to an actual control system point name defined in a configuration file; and
- c) retrieving data for the actual control system point names from a database for processing by the application.
17. The method of claim 16, wherein step c) further comprises retrieving data via a data provider interface, the data provider interface operable to convert between common database access method instructions and other database access instructions.
18. The method of claim 16, further comprising providing the configuration file in XML data format.
19. The method of claim 16, further comprising:
- d) retrieving data from a data mart for processing by the application, the data mart including information previously processed from data obtained from the database.
20. The method of claim 19, wherein the database and the data mart are accessible via a data provider interface, the data provider interface operable to convert between common database access method instructions and other database access instructions.
Type: Application
Filed: Jun 26, 2006
Publication Date: Oct 26, 2006
Inventors: Osman Ahmed (Hawthorn Woods, IL), Pornsak Songkakul (Mequon, MI)
Application Number: 11/474,549
International Classification: G06F 17/30 (20060101);