Conventionally, a solar panel system design is created with significant manual input, even when conventional design software is used, to accommodate regulatory restrictions, obstructions and production estimates. Further, solar panel system designs based on local site information and changes to those designs take manual intervention and time.
The “background” description provided herein is for the purpose of generally presenting the context of the disclosure. Work of the presently named inventors, to the extent it is described in this background section, as well as aspects of the description which may not otherwise qualify as prior art at the time of filing, are neither expressly or impliedly admitted as prior art against the present disclosure.
According to aspects of the disclosed subject matter, generating a photovoltaic system design and proposal includes fetching a maximum solar panel design for a photovoltaic system design from a photovoltaic system design tool; fetching an electricity profile for the photovoltaic system design; receiving one or more modifications to one or more of the photovoltaic system design and an environment of the photovoltaic system; determining customer pricing based on one or more of the modified photovoltaic system design and the modified environment of the photovoltaic system; and generating a customer proposal based on the modified photovoltaic system design and the modified environment of the photovoltaic system.
The foregoing paragraphs have been provided by way of general introduction, and are not intended to limit the scope of the following claims. The described embodiments, together with further advantages, will be best understood by reference to the following detailed description taken in conjunction with the accompanying drawings.
A more complete appreciation of the disclosure and many of the attendant advantages thereof will be readily obtained as the same becomes better understood by reference to the following detailed description when considered in connection with the accompanying drawings, wherein:
The description set forth below in connection with the appended drawings is intended as a description of various embodiments of the disclosed subject matter and is not necessarily intended to represent the only embodiment(s). In certain instances, the description includes specific details for the purpose of providing an understanding of the disclosed subject matter. However, it will be apparent to those skilled in the art that embodiments may be practiced without these specific details. In some instances, well-known structures and components may be shown in block diagram form in order to avoid obscuring the concepts of the disclosed subject matter.
Reference throughout the specification to “one embodiment” or “an embodiment” means that a particular feature, structure, characteristic, operation, or function described in connection with an embodiment is included in at least one embodiment of the disclosed subject matter. Thus, any appearance of the phrases “in one embodiment” or “in an embodiment” in the specification is not necessarily referring to the same embodiment. Further, the particular features, structures, characteristics, operations, or functions may be combined in any suitable manner in one or more embodiments. Further, it is intended that embodiments of the disclosed subject matter can and do cover modifications and variations of the described embodiments.
It must be noted that, as used in the specification and the appended claims, the singular forms “a,” “an,” and “the” include plural referents unless the context clearly dictates otherwise. That is, unless clearly specified otherwise, as used herein the words “a” and “an” and the like carry the meaning of “one or more.” Additionally, it is to be understood that terms such as “left,” “right,” “top,” “bottom,” “front,” “rear,” “side,” “height,” “length,” “width,” “upper,” “lower,” “interior,” “exterior,” “inner,” “outer,” and the like that may be used herein, merely describe points of reference and do not necessarily limit embodiments of the disclosed subject matter to any particular orientation or configuration. Furthermore, terms such as “first,” “second,” “third,” etc., merely identify one of a number of portions, components, points of reference, operations and/or functions as described herein, and likewise do not necessarily limit embodiments of the disclosed subject matter to any particular configuration or orientation.
Referring now to the drawings, wherein like reference numerals designate identical or corresponding parts throughout the several views:
The server 105 can represent one or more servers communicably coupled to the remote device 110 and the PV system design tool 120 via the network 130. The server 105 can be configured to perform various processing for the system 100 as further described herein. Additionally, the server 105 can represent a dedicated bank of servers, cloud-based processing, and/or a serverless computing system corresponding to a virtualized set of hardware resources.
The remote device 110 can represent one or more remote devices communicably coupled to the server 105 and the PV system design tool 120 via the network 130. The remote device 110 can be a computer, laptop, smartphone, tablet, PDA, and the like. The remote device 110 can be operated by a user to interact with the system 100 as further described herein. For example, a salesperson, a dealer, a client, or a current and/or future customer can use the remote device 110 to connect to the system 100 to generate a PV system design and proposal as further described herein.
The PV system design tool 120 can correspond to the photovoltaic system design tool configured to automatically generate a solar design in real time based on received user input as described in U.S. Pat. No. 10,745,999, which is incorporated herein by reference in its entirety. For example, the server 105 and the remote device 110 can receive information from and transmit information to the PV system design tool 120. Additionally, in one aspect, the PV system design tool 120 can be a portion of a software application executed on the remote device 110 where the software application can also include performing a real-time savings estimates, dynamically changing the design in real-time, updating energy production based on the changes to the design in real-time, and update energy production based on changes to a site and/or built environment in real time, for example, as further described herein.
The network 130 can be a public network, such as the Internet, or a private network, such as an LAN or WAN network, or any combination thereof and can also include PSTN or ISDN sub-networks. The network 130 can also be wired, such as an Ethernet network, or can be wireless such as a cellular network including EDGE, 3G, 4G, and 5G wireless cellular systems. The wireless network can also be Wi-Fi, Bluetooth, or any other wireless form of communication that is known.
Generally, the system 100 can use the PV system design tool 120 to deliver a maximum solar panel design corresponding to a predetermined layout of a maximum number of panels that can be placed on a roof in seconds and allows users to change elements of their site for a solar system design in lieu of requesting a maximum solar panel design from a human design team, for example, which may take upwards of two hours and limits user ability to make fundamental changes to the customer maximum solar panel design and home site. In one aspect, the maximum solar panel design can be SunPower's MaxFit design as described in U.S. Pat. No. 10,902,159, which is incorporated herein by reference in its entirety.
More specifically, the system 110 can use the PV system design tool 120 to “automatically” generate a solar design in real time based on the received user input. “Automatically” is used herein to emphasize features of this disclosure, where conventional computer-implemented tasks that previously relied on substantial user input, direction and manipulation (collectively, “user decisions”), by virtue of the teachings of this disclosure, can be decided and implemented by processing circuitry. This significant improvement in speed and efficiency allows multiple designs to be generated in a single day. Because the solar designs can be generated so quickly, updates and modifications to the designs can be made at any time during the design process without derailing the design process.
In S305, a user can interact with a button (e.g., the button 210) of the user interface 205 to trigger a process of generating a solar design and savings estimate.
In S310, the system 100 can fetch a maximum solar panel design from the PV system design tool 120. For example, the PV system design tool 120 can be SunPower's Instant Design as further described in U.S. Pat. No. 10,745,999, which is incorporated herein by reference in its entirety.
In S315, the system 100 can fetch an electricity profile from a customer relationship management platform. For example, the system 100 aggregates all customers within the given zip code of the customer's home to determine the most popular utility tariff to model savings after. The monthly average electricity bill provided by the user is then extrapolated into annual savings based on actual electricity costs for that site.
In S320, the system 100 can modify system and environment attributes. For example, the system 100 considers height data for the customer's home site, which includes environmental attributes such as neighboring structures (e.g., buildings, houses, telephone poles, etc.) and flora (e.g., trees). This data could impact the solar access that is estimated for the generated solar design.
In S325, the system 100 can add customer pricing. For example, the user can input their desired sales commission or system price in order to achieve desired customer pricing inclusive of state and local solar incentives for presentation. These purchase options can include Cash, Lease and Loan side-by-side for selection.
In S330, the system 100 can generate a customer proposal. For example, once the user has completed the solar design and added their desired sales commission or system price for product pricing, the user can then generate a customer specific solar proposal which highlights various aspects of the solar value proposition including system design, system components, estimated savings/return, and purchase options. After generating the customer proposal in S330, the process can end.
Additionally, the system 100 can update changes in energy data in real time. In other words, as a user modifies panel location, the displayed energy data can change in real time in response. For example, the roof plane has defined solar insolation and shade (e.g., solar access) for every point on the roof. By changing a panel location, a new solar insolation value for the panel is calculated based on the panel's new area location. Then, energy production values and all downstream calculations are re-calculated. Design edits that result in updating the energy data include adding or removing panels, moving panels, rotating panels, and the like.
In S705, the system 100 can determine if the PV system design is modified. For example, the PV system design can be modified as described in
In S715, the system 100 can add customer pricing.
In S720, the system 100 can generate a customer proposal.
However, in response to a determination in S705 that the PV system design has been modified, the system 100 can receive activation and/or deactivation of one or more existing solar panels in S725. For example, a user can interact with the user interface 405 to activate and/or deactivate one or more existing solar panels in the design (e.g., by clicking/tapping on the solar panel).
In S730, the system 100 can receive movement of one or more solar panels. For example, a user can interact with the user interface 405 to move one or more solar panels (e.g., click and hold to drag the solar panel to a different location).
In S735, the system 100 can be configured to add a new panel based on user input and mirror an existing array.
It should be appreciated that for each of S725, S730, and S735, one or more of these steps can be performed and it is not required that they all be performed.
In S740, it can be determined for each of S725, S730, and S735 that did occur whether the design modification falls within local AHJ roof setbacks. In response to a determination that the design modification is not within the local AHJ roof setbacks, the process can return to S725, S730, and/or S735 to receive another design modification to determine if that design modification is within the local AHJ roof setback. However, in response to a determination that the design modification is within the local AHJ roof setbacks, the system 100 can fetch panel (e.g., solar panel) level production for each panel based on panel location (e.g., one or more of geographical location of the panel and a location and orientation of the panel on the roof) in S745. The AHJ information for the design is being fetched from an AHJ database stored in the customer relationship management platform. After fetching panel level production based on panel location in S745, the process can continue to S710 to display updated PV system production.
After the customer proposal is generated in S720, the process can end.
In S905, the system 100 can determine if the built environment is modified. For example, the built environment can be modified as described in
In S915, the system 100 can compute system production (e.g., energy production corresponding to system production of the PV system in the built environment).
In S920, the system 100 can display updated system production. For example, the updated system production can be displayed by the user interface 805.
In S925, the system 100 can add customer pricing.
In S930, the system 100 can generate a customer proposal. In one aspect, the customer proposal includes marketing material, the financial product/cost value proposition, and solar system specifications.
However, in response to a determination that the built environment has been modified, the system 100 can receive user input to add or remove one or more roof obstructions in the built PV system environment in S935. For example, in one or more aspects of the disclose subject matter, user input can refer to a user clicking with a mouse and/or tapping on a tablet or smartphone with their finger.
In S940, the system 100 can receive user input to change a shape and/or height of roof obstructions in the built PV system environment.
In S945, the system 100 can receive user input to add or remove one or more trees in the built PV system environment. For example, trees within a predetermined distance of the PV system can block some portion of sunlight from reaching one or more PV panels in the PV system.
In S950, the system 100 can receive user input to change a shape and/or height of one or more trees in the built PV system environment.
It should be appreciated that for each of S935, S940, S945, and S950, one or more of these steps can be performed and it is not required that they all be performed.
In S955, the system 100 can update a 3D model of the built PV system environment based on any changes received from S935-S950. After updating the 3D model, the process can return to S910 to run updated irradiance.
After the customer proposal is generated in S930, the process can end.
The system 100 includes many advantages. For example, the system 100 solves the delay in providing homeowners with an accurate, customer designed solar system with a supporting value proposition. The value is that homeowners can quickly qualify themselves and their home for solar energy in the matter of minutes, which is something that traditionally takes hours.
In the above description of
The present disclosure may be embodied as a system, a method, and/or a computer program product. The computer program product may include a computer readable storage medium on which computer readable program instructions are recorded that may cause one or more processors to carry out aspects of the embodiment.
The computer readable storage medium may be a tangible device that can store instructions for use by an instruction execution device (processor). The computer readable storage medium may be, for example, but is not limited to, an electronic storage device, a magnetic storage device, an optical storage device, an electromagnetic storage device, a semiconductor storage device, or any appropriate combination of these devices. A non-exhaustive list of more specific examples of the computer readable storage medium includes each of the following (and appropriate combinations): flexible disk, hard disk, solid-state drive (SSD), random access memory (RAM), read-only memory (ROM), erasable programmable read-only memory (EPROM or Flash), static random access memory (SRAM), compact disc (CD or CD-ROM), digital versatile disk (DVD) and memory card or stick. A computer readable storage medium, as used in this disclosure, is not to be construed as being transitory signals per se, such as radio waves or other freely propagating electromagnetic waves, electromagnetic waves propagating through a waveguide or other transmission media (e.g., light pulses passing through a fiber-optic cable), or electrical signals transmitted through a wire.
Computer readable program instructions described in this disclosure can be downloaded to an appropriate computing or processing device from a computer readable storage medium or to an external computer or external storage device via a global network (i.e., the Internet), a local area network, a wide area network and/or a wireless network. The network may include copper transmission wires, optical communication fibers, wireless transmission, routers, firewalls, switches, gateway computers and/or edge servers. A network adapter card or network interface in each computing or processing device may receive computer readable program instructions from the network and forward the computer readable program instructions for storage in a computer readable storage medium within the computing or processing device.
Computer readable program instructions for carrying out operations of the present disclosure may include machine language instructions and/or microcode, which may be compiled or interpreted from source code written in any combination of one or more programming languages, including assembly language, Basic, Fortran, Java, Python, R, C, C++, C# or similar programming languages. The computer readable program instructions may execute entirely on a user's personal computer, notebook computer, tablet, or smartphone, entirely on a remote computer or compute server, or any combination of these computing devices. The remote computer or compute server may be connected to the user's device or devices through a computer network, including a local area network or a wide area network, or a global network (i.e., the Internet). In some embodiments, electronic circuitry including, for example, programmable logic circuitry, field-programmable gate arrays (FPGA), or programmable logic arrays (PLA) may execute the computer readable program instructions by using information from the computer readable program instructions to configure or customize the electronic circuitry, in order to perform aspects of the present disclosure.
Aspects of the present disclosure are described herein with reference to flow diagrams and block diagrams of methods, apparatus (systems), and computer program products according to embodiments of the disclosure. It will be understood by those skilled in the art that each block of the flow diagrams and block diagrams, and combinations of blocks in the flow diagrams and block diagrams, can be implemented by computer readable program instructions.
The computer readable program instructions that may implement the systems and methods described in this disclosure may be provided to one or more processors (and/or one or more cores within a processor) of a general purpose computer, special purpose computer, or other programmable apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable apparatus, create a system for implementing the functions specified in the flow diagrams and block diagrams in the present disclosure. These computer readable program instructions may also be stored in a computer readable storage medium that can direct a computer, a programmable apparatus, and/or other devices to function in a particular manner, such that the computer readable storage medium having stored instructions is an article of manufacture including instructions which implement aspects of the functions specified in the flow diagrams and block diagrams in the present disclosure.
The computer readable program instructions may also be loaded onto a computer, other programmable apparatus, or other device to cause a series of operational steps to be performed on the computer, other programmable apparatus or other device to produce a computer implemented process, such that the instructions which execute on the computer, other programmable apparatus, or other device implement the functions specified in the flow diagrams and block diagrams in the present disclosure.
Referring to
Additional detail of computer 1005 is shown in
Computer 1005 may be a personal computer (PC), a desktop computer, laptop computer, tablet computer, netbook computer, a personal digital assistant (PDA), a smart phone, or any other programmable electronic device capable of communicating with other devices on network 1010. In one aspect, the computer 1005 may correspond to the remote device 110.
Computer 1005 may include processor 1035, bus 1037, memory 1040, non-volatile storage 1045, network interface 1050, peripheral interface 1055 and display interface 1065. Each of these functions may be implemented, in some embodiments, as individual electronic subsystems (integrated circuit chip or combination of chips and associated devices), or, in other embodiments, some combination of functions may be implemented on a single chip (sometimes called a system on chip or SoC).
Processor 1035 may be one or more single or multi-chip microprocessors, such as those designed and/or manufactured by Intel Corporation, Advanced Micro Devices, Inc. (AMD), Arm Holdings (Arm), Apple Computer, etc. Examples of microprocessors include Celeron, Pentium, Core i3, Core i5 and Core i7 from Intel Corporation; Opteron, Phenom, Athlon, Turion and Ryzen from AMD; and Cortex-A, Cortex-R and Cortex-M from Arm.
Bus 1037 may be a proprietary or industry standard high-speed parallel or serial peripheral interconnect bus, such as ISA, PCI, PCI Express (PCI-e), AGP, and the like.
Memory 1040 and non-volatile storage 1045 may be computer-readable storage media. Memory 1040 may include any suitable volatile storage devices such as Dynamic Random Access Memory (DRAM) and Static Random Access Memory (SRAM). Non-volatile storage 1045 may include one or more of the following: flexible disk, hard disk, solid-state drive (SSD), read-only memory (ROM), erasable programmable read-only memory (EPROM or Flash), compact disc (CD or CD-ROM), digital versatile disk (DVD) and memory card or stick.
Program 1048 may be a collection of machine readable instructions and/or data that is stored in non-volatile storage 1045 and is used to create, manage and control certain software functions that are discussed in detail elsewhere in the present disclosure and illustrated in the drawings. In some embodiments, memory 1040 may be considerably faster than non-volatile storage 1045. In such embodiments, program 1048 may be transferred from non-volatile storage 1045 to memory 1040 prior to execution by processor 1035.
Computer 1005 may be capable of communicating and interacting with other computers via network 1010 through network interface 1050. Network 1010 may be, for example, a local area network (LAN), a wide area network (WAN) such as the Internet, or a combination of the two, and may include wired, wireless, or fiber optic connections. In general, network 1010 can be any combination of connections and protocols that support communications between two or more computers and related devices.
Peripheral interface 1055 may allow for input and output of data with other devices that may be connected locally with computer 1005. For example, peripheral interface 1055 may provide a connection to external devices 1060. External devices 1060 may include devices such as a keyboard, a mouse, a keypad, a touch screen, and/or other suitable input devices. External devices 1060 may also include portable computer-readable storage media such as, for example, thumb drives, portable optical or magnetic disks, and memory cards. Software and data used to practice embodiments of the present disclosure, for example, program 1048, may be stored on such portable computer-readable storage media. In such embodiments, software may be loaded onto non-volatile storage 1045 or, alternatively, directly into memory 1040 via peripheral interface 1055. Peripheral interface 1055 may use an industry standard connection, such as RS-232 or Universal Serial Bus (USB), to connect with external devices 1060.
Display interface 1065 may connect computer 1005 to display 1070. Display 1070 may be used, in some embodiments, to present a command line or graphical user interface to a user of computer 1005. Display interface 1065 may connect to display 1070 using one or more proprietary or industry standard connections, such as VGA, DVI, DisplayPort and HDMI.
As described above, network interface 1050, provides for communications with other computing and storage systems or devices external to computer 1005. Software programs and data discussed herein may be downloaded from, for example, remote computer 1015, web server 1020, cloud storage server 1025 and compute server 1030 to non-volatile storage 1045 through network interface 1050 and network 1010. Furthermore, the systems and methods described in this disclosure may be executed by one or more computers connected to computer 1005 through network interface 1050 and network 1010. For example, in some embodiments the systems and methods described in this disclosure may be executed by remote computer 1015, computer server 1030, or a combination of the interconnected computers on network 1010.
Data, datasets and/or databases employed in embodiments of the systems and methods described in this disclosure may be stored and or downloaded from remote computer 1015, web server 1020, cloud storage server 1025 and compute server 1030.
Obviously, numerous modifications and variations of the present disclosure are possible in light of the above teachings. It is therefore to be understood that within the scope of the appended claims, the disclosure may be practiced otherwise than as specifically described herein.
Having now described embodiments of the disclosed subject matter, it should be apparent to those skilled in the art that the foregoing is merely illustrative and not limiting, having been presented by way of example only. Thus, although particular configurations have been discussed herein, other configurations can also be employed. Numerous modifications and other embodiments (e.g., combinations, rearrangements, etc.) are enabled by the present disclosure and are within the scope of one of ordinary skill in the art and are contemplated as falling within the scope of the disclosed subject matter and any equivalents thereto. Features of the disclosed embodiments can be combined, rearranged, omitted, etc., within the scope of the invention to produce additional embodiments. Furthermore, certain features may sometimes be used to advantage without a corresponding use of other features.
Accordingly, Applicant(s) intend(s) to embrace all such alternatives, modifications, equivalents, and variations that are within the spirit and scope of the disclosed subject matter.
This application claims the benefit of U.S. Provisional Application No. 63/144,190, filed Feb. 1, 2021, which is incorporated herein by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
63144190 | Feb 2021 | US |