The claimed subject matter relates to the field of software, and more particularly to the creation of software from library components and custom components.
Communication network 125 may itself be comprised of many interconnected computer systems and communication links. Communication links 130 may be hardwire links, optical links, satellite or other wireless communications links, wave propagation links, or any other mechanisms for communication of information. Various communication protocols may be used to facilitate communication between the various systems shown in
System 100 in
Client systems 105, 110, and 115 typically request information from a server system which provides the information. Server systems by definition typically have more computing and storage capacity than client systems. However, a particular computer system may act as both a client and a server depending on whether the computer system is requesting or providing information. Aspects of the system may be embodied using a client-server environment or a cloud-cloud computing environment.
Server 120 is responsible for receiving information requests from client systems 105, 110, and 115, performing processing required to satisfy the requests, and for forwarding the results corresponding to the requests back to the requesting client system. The processing required to satisfy the request may be performed by server system 120 or may alternatively be delegated to other servers connected to communication network 125.
Client systems 105, 110, and 115 enable users to access and query information or applications stored by server system 120. Some example client systems include portable electronic devices (e.g., mobile communication devices) such as the Apple iPhone®, the Apple iPad®, the Palm Pre™, or any device running the Apple iOS™, Android™ OS, Google Chrome OS, Symbian OS®, Windows Mobile® OS, Palm OS® or Palm Web OS™. In a specific embodiment, a “web browser” application executing on a client system enables users to select, access, retrieve, or query information and/or applications stored by server system 120. Examples of web browsers include the Android browser provided by Google, the Safari® browser provided by Apple, the Opera Web browser provided by Opera Software, the BlackBerry® browser provided by Research In Motion, the Internet Explorer® and Internet Explorer Mobile browsers provided by Microsoft Corporation, the Firefox® and Firefox for Mobile browsers provided by Mozilla®, and others.
Input device 215 may also include a touchscreen (e.g., resistive, surface acoustic wave, capacitive sensing, infrared, optical imaging, dispersive signal, or acoustic pulse recognition), keyboard (e.g., electronic keyboard or physical keyboard), buttons, switches, stylus, gestural interface (contact or non-contact gestures), biometric input sensors, or combinations of these.
Mass storage devices 240 may include flash and other nonvolatile solid-state storage or solid-state drive (SSD), such as a flash drive, flash memory, or USB flash drive. Other examples of mass storage include mass disk drives, floppy disks, magnetic disks, optical disks, magneto-optical disks, fixed disks, hard disks, CD-ROMs, recordable CDs, DVDs, recordable DVDs (e.g., DVD-R, DVD+R, DVD-RW, DVD+RW, HD-DVD, or Blu-ray Disc), battery-backed-up volatile memory, tape storage, reader, and other similar media, and combinations of these.
System 100 may also be used with computer systems having different configurations, e.g., with additional or fewer subsystems. For example, a computer system could include more than one processor (i.e., a multiprocessor system, which may permit parallel processing of information) or a system may include a cache memory. The computer system shown in
A computer-implemented or computer-executable version of the program instructions useful to practice the present invention may be embodied using, stored on, or associated with computer-readable medium. A computer-readable medium may include any medium that participates in providing instructions to one or more processors for execution. Such a medium may take many forms including, but not limited to, nonvolatile, volatile, and transmission media. Nonvolatile media includes, for example, flash memory, or optical or magnetic disks. Volatile media includes static or dynamic memory, such as cache memory or RAM. Transmission media includes coaxial cables, copper wire, fiber optic lines, and wires arranged in a bus. Transmission media can also take the form of electromagnetic, radio frequency, acoustic, or light waves, such as those generated during radio wave and infrared data communications.
For example, a binary, machine-executable version, of the software useful to practice the present invention may be stored or reside in RAM or cache memory, or on mass storage device 240. The source code of this software may also be stored or reside on mass storage device 240 (e.g., flash drive, hard disk, magnetic disk, tape, or CD-ROM). As a further example, code useful for practicing the invention may be transmitted via wires, radio waves, or through a network such as the Internet. In another specific embodiment, a computer program product including a variety of software program code to implement features of the invention is provided.
Computer software products may be written in any of various suitable programming languages, such as C, C++, C#, Pascal, Fortran, Perl, Matlab (from MathWorks, www.mathworks.com), SAS, SPSS, JavaScript, CoffeeScript, Objective-C, Objective-J, Ruby, Python, Erlang, Lisp, Scala, Clojure, and Java. The computer software product may be an independent application with data input and data display modules. Alternatively, the computer software products may be classes that may be instantiated as distributed objects. The computer software products may also be component software such as Java Beans (from Oracle) or Enterprise Java Beans (EJB from Oracle).
An operating system for the system may be the Android operating system, iPhone OS (i.e., iOS), Symbian, BlackBerry OS, Palm web OS, bada, MeeGo, Maemo, Limo, or Brew OS. Other examples of operating systems include one of the Microsoft Windows family of operating systems (e.g., Windows 95, 98, Me, Windows NT, Windows 2000, Windows XP, Windows XP x64 Edition, Windows Vista, Windows 7, Windows CE, Windows Mobile, Windows Phone 7), Linux, HP-UX, UNIX, Sun OS, Solaris, Mac OS X, Alpha OS, AIX, IRIX32, or IRIX64. Other operating systems may be used.
Furthermore, the computer may be connected to a network and may interface to other computers using this network. The network may be an intranet, internet, or the Internet, among others. The network may be a wired network (e.g., using copper), telephone network, packet network, an optical network (e.g., using optical fiber), or a wireless network, or any combination of these. For example, data and other information may be passed between the computer and components (or steps) of a system useful in practicing the invention using a wireless network employing a protocol such as Wi-Fi (IEEE standards 802.11, 802.11a, 802.11b, 802.11e, 802.11g, 802.11i, and 802.11n, just to name a few examples). For example, signals from a computer may be transferred, at least in part, wirelessly to components or other computers.
Computing device 305 may run a software-creating component 315 which may be provided with a subset of code sections (e.g., subset 345a from server 320 via user application 310) that software-creating component 315 (like server 320) may assemble into customized software (e.g., customized software 350a).
Network 325 may be any suitable communications network. Communication network 325 may itself be comprised of many interconnected computer systems and communication links. As an example and not by way of limitation, one or more portions of network 325 may include an ad hoc network, an intranet, an extranet, a virtual private network (VPN), a local area network (LAN), a wireless LAN (WLAN), a wide area network (WAN), a wireless WAN (WWAN), a metropolitan area network (MAN), a portion of the Internet, a portion of the Public Switched Telephone Network (PSTN), a cellular telephone network, another suitable network, or a combination of two or more of these. Network 325 may include one or more networks 325.
Connections 330 may connect computing device 305 and server 320 to communication network 325 or to each other. Communication links 330 may be hardwire links, optical links, satellite or other wireless communications links, wave propagation links, or any other mechanisms for communication of information. This disclosure contemplates any suitable connections 325. In particular embodiments, one or more connections 325 include one or more wireline (such as for example Digital Subscriber Line (DSL) or Data Over Cable Service Interface Specification (DOCSIS)), wireless (such as for example Wi-Fi or Worldwide Interoperability for Microwave Access (WiMAX)) or optical (such as for example Synchronous Optical Network (SONET) or Synchronous Digital Hierarchy (SDH)) connections. In particular embodiments, one or more connections 330 each include an ad hoc network, an intranet, an extranet, a VPN, a LAN, a WLAN, a WAN, a WWAN, a MAN, a portion of the Internet, a portion of the PSTN, a cellular telephone network, another suitable connection 330, or a combination of two or more such connections 330. Connections 330 need not necessarily be the same throughout system 300. One or more first connections 330 may differ in one or more respects from one or more second connections 330.
Server 320 may be a network-addressable computing system that can host one or more product databases 340. Server 320 may be responsible for receiving information requests from computing device 305 via user application 310, for performing the processing required to satisfy the requests, for generating responses (e.g., custom software 350a, . . . , 350n) to received inquiries, and for forwarding the results corresponding to the requests back to requesting computing device 305. Server 320 may store, receive, or transmit data and software, and information associated with the data and software (including user data). The processing required to satisfy the requests may be performed by server 320 or may alternatively be delegated to other servers connected to communication network 325. For example, other servers may host database 340, or have additional databases. Server 320 may be an intermediary in communications between a computing device 305 and another server system, or a computing device 305 may communicate directly with another server system. Server 320 may be accessed by the other components of system 300, for example, directly or via network 325. In particular embodiments, one or more users 301 may use one or more computer devices 305 to access, send data to, and receive data from server 320.
Computing device 305, connections 330, and network 325, enable user 301 to access and query information stored and applications run by server 320, such as database 340. Some example computer devices 305 include desktop computers, portable electronic devices (e.g., mobile communication devices, smartphones, tablet computers, laptops) such as the Samsung Galaxy Tab®, Google Nexus devices, Amazon Kindle®, Kindle Fire®, Apple iPhone®, the Apple iPad®, Microsoft Surface®, the Palm Pre™, or any device running the Apple iOS®, Android® OS, Google Chrome® OS, Symbian OS®, Windows Mobile® OS, Windows Phone, BlackBerry® OS, Embedded Linux, Tizen, Sailfish, webOS, Palm OS® or Palm Web OS®.
In an embodiment, user application 310 may be run or executed by a different system. For example, computing device 305, or server 320, or both, may run user application 310. That is, user application 310 may be run by computing device 305, or the application may be run on server 320 and accessed by computing device 305 through a browser and network 325. For example, computing device 305 could be operated as a terminal, with user application 310 being run on a server, e.g., server 320. In an embodiment, aspects or functionalities of user application 310 are run by server 320, or another computing system or server. In an embodiment, the steps of the methods described herein may be performed, at least in part, in cloud-computing environment.
In an embodiment, a method for creating software is called “Engineer.ai.”
Why was Engineer.ai created? Engineer.ai was created to allow for the building of digital products at least 30% faster and for 30% less than anyone else in the industry, all while guaranteeing top quality.
What is it and how does it work? Engineer.ai is an “as-a-service” platform for software outsourcing, turning App Development/Software Outsourcing into something as simple as a restaurant menu that you can pick a-la carte. This includes an On-Demand & Online Price Calculator for building any digital product from a Wearable to a Marketplace to an App with price guarantees, and intelligent automation/machine assistance that reduces the average cost and time of any project by at least 30%-40%. Engineer.ai offers a transparent fixed price upfront. No surprises and any amount over your fixed price is waived.
How does the service/product work? Engineer.ai provides an intuitive and easy-to-use wizard for pricing any idea in less than 60 seconds with pre-set options made available based on the project type. The fixed price you get is offered immediately and upfront. You don't need to wait or speak to a salesperson to know exactly what your project will cost and how long it will take to deliver.
How is my project managed? Engineer.ai provides weekly updates so you always know the exact status of your project. Engineer.ai practices gold standard for coding so quality is never sacrificed. Engineer.ai offers a weekly subscription and billing model so you are never locked in and can pause, speed up, or walk away at anytime.
Engineer.ai Benefits
Engineer.ai Description
Engineer.ai uses machines to automate and institutionalize as much of the software outsourcing process as possible. Engineer.ai includes transparent pricing, standardized delivery, and a manufacturing-styled approach to development that reuses an estimated 50% of code and design that is often standardized and duplicated across many apps and digital platforms.
A key part of our business model is how Engineer.ai actually scales and builds. Engineer.ai scales by using 3rd party dev shops/contractors and having them deliver under the Engineer.ai brand, and Engineer.ai uses code libraries. Similarly Engineer.ai lets Software Companies get predictable revenue, a framework that lets them get paid and a way for them to access our rich code libraries & SIMBA Platform (Simple, Integrated, Machine-Based, Architecture Platform). Engineer.ai also scales by the institutionalization of the Engineer.ai code and development process.
SIMBA connects the entire product delivery process together. It integrates on-boarding, pricing, engineering and product/project management using machine-learning processing and A.I. (“artificial intelligence”) to keep constant conversation with the customer. Aspects of SIMBA include:
Engineer.ai is the first service to unify Development Shops around the world:
Role of SIMBA in Engineering.ai:
Engineer.ai—Features
Engineer.ai—Additional Features
Engineer.ai—Partner Development Qualification Process
TABLE 1 gives a description of pages from a website employing embodiments of a method for creating software from library and custom components. In TABLE 1, a particular webpage is identified by the columns: ID, Title, and Labels. A Description column includes a description of the particular webpage and its function.
In the description above and throughout, numerous specific details are set forth in order to provide a thorough understanding of an embodiment of this disclosure. It will be evident, however, to one of ordinary skill in the art, that an embodiment may be practiced without these specific details. In other instances, well-known structures and devices are shown in block diagram form to facilitate explanation. The description of the preferred embodiments is not intended to limit the scope of the claims appended hereto. Further, in the methods disclosed herein, various steps are disclosed illustrating some of the functions of an embodiment. These steps are merely examples, and are not meant to be limiting in any way. Other steps and functions may be contemplated without departing from this disclosure or the scope of an embodiment.
Systems and methods are described for creating software from library and custom components. In a method for creating software, a server running a software creating component may receive input from a customer, where the input describes at least one aspect of a software program. Based on the input, the software creating component may determine existing code components that may be used to create the software program, where the existing code components are stored in a code library accessible by the software creating component. Based on the user input and based on the existing code components that may be used to create the software program, the software creating component may determine new code components that must be developed for the software program. And, based on the existing code components that may be used and based on the new code components that must be developed, the software creating component may provide, to the user, a cost estimate for the software program.
Different embodiments may provide variations on the basic principles outlined above. In an embodiment, the method may further comprise adjusting the cost estimate based on the at least one aspect of the software program. In an embodiment, the at least one aspect of the software program may include at least one of: a platform category, an application template, a requirement collection, a platform, a number of screens, a feature, a team location, a time to market, and a build depth. In an embodiment, the build depth may include: a wireframe, a design, a navigable prototype, a minimal viable product, or a complete project. In an embodiment, the method may further comprise: sending, by the software creating program, a set of existing code requirement and a set of new code requirements to a team selector; and generating, by the software creating program, a project template based on the existing code components that may be used and based on the new code components that must be developed. In an embodiment, the method may further comprise: generating, by the software creating program, a project schedule based at least in part on the project template, the project schedule including events related to the creation of the software program; and managing, by the software creating program, the events related to the creation of the software program. In an embodiment, the events related to the creation of the software program may include at least one of: a project milestone; a code commit; and a customer message. In an embodiment, the method may further comprise: passing, by the software creating program, at least one event ID to a communication program; and sending, by the communication program, a message to the customer based on the event ID. And in an embodiment, the method may further comprise: receiving, by a communication program, a message from the customer; and parsing, by the communication program, the received message into the software creating program.
This Application is a Continuation of application Ser. No. 17/380,456 filed on Jul. 20, 2021. Application Ser. No. 17/380,456 is a Continuation of application Ser. No. 16/854,805 filed on Apr. 21, 2020. Application Ser. No. 16/854,805 is a Continuation of application Ser. No. 15/786,431 filed on Oct. 17, 2017. Application Ser. No. 15/786,431 claims the benefit of U.S. Provisional Application 62/408,935 filed on Oct. 17, 2016. The entire contents of these applications are incorporated herein by reference in their entirety.
Number | Name | Date | Kind |
---|---|---|---|
6016394 | Walker | Jan 2000 | A |
6697824 | Bowman-Amuah | Feb 2004 | B1 |
7783523 | Lopez | Aug 2010 | B2 |
8144619 | Hoffberg | Mar 2012 | B2 |
8146053 | Morrow et al. | Mar 2012 | B2 |
8365018 | McIntosh et al. | Jan 2013 | B2 |
8458009 | Southworth | Jun 2013 | B1 |
8621423 | Knight | Dec 2013 | B2 |
8893212 | Reisman | Nov 2014 | B2 |
9286040 | Halley | Mar 2016 | B2 |
9563407 | Salter | Feb 2017 | B2 |
10649741 | Duggal | May 2020 | B2 |
10798028 | Fung | Oct 2020 | B2 |
11086599 | Duggal | Aug 2021 | B2 |
20030018952 | Roetzheim | Jan 2003 | A1 |
20050066304 | Tattrie et al. | Mar 2005 | A1 |
20060259442 | Iqbal | Nov 2006 | A1 |
20080004844 | Kefford | Jan 2008 | A1 |
20080235155 | Thywissen | Sep 2008 | A1 |
20090037287 | Baitalmal | Feb 2009 | A1 |
20110088011 | Ouali | Apr 2011 | A1 |
20110276354 | Bijani et al. | Nov 2011 | A1 |
20120331439 | Zimmermann et al. | Dec 2012 | A1 |
20160055079 | Hanna | Feb 2016 | A1 |
20160092179 | Straub | Mar 2016 | A1 |
20210349695 | Duggal | Nov 2021 | A1 |
20220236958 | Duggal et al. | Jul 2022 | A1 |
20220241548 | Duggal et al. | Aug 2022 | A1 |
20220244921 | Duggal et al. | Aug 2022 | A1 |
20220244922 | Duggal et al. | Aug 2022 | A1 |
20220244923 | Duggal et al. | Aug 2022 | A1 |
20220326914 | Duggal et al. | Oct 2022 | A1 |
20220342642 | Duggal et al. | Oct 2022 | A1 |
Number | Date | Country |
---|---|---|
101975272 | May 2019 | KR |
Entry |
---|
Dekkers, “Beyond Development: Estimating Model for Run & Maintain Cost”, 2007, Software Measurement European Forum, Italy, pp. 249-264. (Year: 2007). |
Nathan Curtis, “Modular Web Design—Creating Reusable Components for User Experience Design”, 2010, Peachpit Press, 328 pages. (Year: 2010). |
Sharlene Aminullah, “Cost Estimation of Service Delivery in Cloud Computing”, Aug. 2012, Arjuna Technologies Ltd., 95 pages. (Year: 2012). |
Notification of Transmittal of the International Search Report and the Written Opinion of the International Searching Authority, or the Declaration for International Application No. PCT/US2017/057030, International Filing Date Oct. 17, 2017, dated Jan. 4, 2018, 7 pages. |
Angel Puerta et al., “The UI Pilot: A Model-Based Tool to Guide Early Interface Design”, 2005, ACM, pp. 215-222 (Year: 2005). |
International Search Report and the Written Opinion, International Application No. PCT/EP2020/085866, dated Mar. 31, 2021 (11 poages). |
Bernaschina et al., “Online Model Editing, Simulation and Code Generation for Web and Mobile Applications,” IEEE, pp. 33-37 (2017). |
Bernaschina et al., “Formal Semantics of OMG's Interaction Flow Modeling Language (IFML) for Mobile and Rich-Client Application Model Driven Development,” Elsevier, pp. 239-260 (2017). |
Number | Date | Country | |
---|---|---|---|
20220241548 A1 | Aug 2022 | US |
Number | Date | Country | |
---|---|---|---|
62408935 | Oct 2016 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 17380456 | Jul 2021 | US |
Child | 17722089 | US | |
Parent | 16854805 | Apr 2020 | US |
Child | 17380456 | US | |
Parent | 15786431 | Oct 2017 | US |
Child | 16854805 | US |