Automotive shape design is a challenging problem as it involves the confluence of several different fields of study. For example, automotive shape design may involve both engineering and aesthetic considerations. This necessitates a multi-disciplinary approach to undertake the design and development of next-generation cars. For instance, Computational Fluid Dynamics (CFD) is used in the aerodynamic shape optimization to lower the aerodynamic drag coefficient of automobiles so that the shape of the vehicle is streamlined. This allows improved energy usage—whether it is fuel consumption for diesel/gasoline vehicles or battery usage for electric vehicles—since the aerodynamic drag is reduced. Likewise, the aesthetic style of cars is also critical as it has a better selling value to the customer. For instance, a sporty car shape appeals to younger customers, whereas a sedan has a better appeal to another cross section of customers; or a pick-up truck has appeal to yet another customer cross-section. A vehicle with the best performance-related aerodynamic shape may not meet the aesthetic expectations of a customer. Likewise, a vehicle that appeals to the customer in appearance may not have an aerodynamic shape that has a low drag coefficient. It is thus warranted to combine aerodynamics and aesthetics into the design process so that one can design automobiles with the best of both approaches.
Traditionally, cars are designed by different groups of engineers with different aspects addressed by the different groups of designers. For instance, CFD engineers optimize the external shape of cars to satisfy lower drag requirements. In parallel, body silhouette design engineers address the aesthetic/style looks of the car once the shape is finalized. This separation of two different aspects of car design is not desired as the car with the best aerodynamic shape need not have the best appeal to the customer, and vice versa. Accordingly, there is a need to improve the field of automotive or industrial shape design.
A detailed description is set forth regarding the accompanying drawings. The use of the same reference numerals may indicate similar or identical items. Various embodiments may utilize elements and/or components other than those illustrated in the drawings, and some elements and/or components may not be present in various embodiments. Elements and/or components in the figures are not necessarily drawn to scale. Throughout this disclosure, depending on the context, singular and plural terminology may be used interchangeably.
The present disclosure is directed to systems and methods for industrial shape design. Industrial shape design may cover the design of various parts for automobiles, airplanes, and more. While various embodiments described in greater detail below will reference automotive shape design, it should be understood that such techniques may be applicable to other types of designs, including but not limited to airplane shape design, drone shape design, and other such industrial contexts.
Traditionally, cars have been designed by different groups of engineers with different aspects addressed by the different groups of designers. For instance, Computational Fluid Dynamics (CFD) engineers optimize the external shape of cars to satisfy lower drag requirements. In parallel, body silhouette design engineers may address the aesthetic/style looks of the car once the shape is finalized. This separation of two different aspects of car design is not ideal as the car with the best aerodynamic shape need not have the best appeal to the customer, and vice versa. Techniques described herein below may be used to address such different design aspects by combining both aerodynamic and aesthetic considerations.
In a first embodiment contemplated within the scope of this disclosure, Computational Fluid Dynamics (CFD) is used a priori to obtain a set of candidate shapes of the car that have low aerodynamic drag coefficients. They are then provided as inputs to a pre-trained conditional Generative Adversarial Network (GAN) to output photo-realistic images of cars with high customer appeal and aesthetic styles for the optimized shape. In addition, the GAN may also involve the use of different input latent noise vectors to produce different photo-realistic images of styles, given the CFD-optimized shape. These additional input parameters may be used to provide the user with photo-realistic images where the wheel designs, car shapes aspect ratio, etc., can be customized.
In a second embodiment contemplated within the scope of this disclosure, the process described above is effectively reversed—a pre-trained Generative Adversarial Network (GAN) is used to output vehicle shapes with aesthetic styles, wheel designs, car shapes, aspect ratios, etc. that are inferred to have a high aesthetic appeal to customers. The output silhouette shapes are fed into a Computational Fluid Dynamics (CFD) solver to estimate the aerodynamic drag coefficient. Drag coefficients may be computed for the candidate shapes, and only those shapes that have a drag coefficient below a certain threshold value are progressed to the next step of the design and development process.
Accordingly, by combining the use of Computational Fluid Dynamics (CFD) and Generative Adversarial Network (GAN) techniques, a discovery environment may be implemented that allows the exploration of a large design space for the selection of an optimal design that satisfies multiple competing objectives, such as aerodynamic and aesthetic considerations.
In at least one embodiment, multi-disciplinary systems and methods are devised for the design of the next-generation automobiles, airplanes, etc. that combine Computational Fluid Dynamics (CFD) and computer vision. The overall methodology comprises a two-step process, according to at least one embodiment.
It should be noted that the terms “first step” and “second step” as described above are not intended to imply or require a specific order in which different steps of an automobile shape design process are performed. For example, the second step may be performed prior to the first step, or the first step may be performed prior to the second step. It should be appreciated that such relative terms are meant merely to organizationally describe different steps of an automobile shape design process and not to enforce a specific ordering of such different steps, unless clear from context.
A GAN architecture utilized in the context of various embodiments may be designed in a way that exposes novel ways to control the image synthesis process. StyleGAN-based network described herein may start from a learned constant input and adjusts the “style” of the image at each convolution layer based on the latent code, therefore directly controlling the strength of image features at different scales. Combined with noise injected directly into the network, this architectural change leads to automatic, unsupervised separation of high-level attributes from stochastic variation in the generated images, and enables intuitive scale-specific mixing and interpolation operations. A vehicle outline shape 302 may be provided as an input to the GAN model.
With reference to
where each feature map xi is normalized separately, and then scaled and biased using the corresponding scalar components from style y. Thus the dimensionality of y is twice the number of feature maps on that layer.
Finally, the generator is provided with a direct means to generate stochastic detail by introducing explicit noise inputs. In various embodiments, these are introduced as single-channel images of uncorrelated Gaussian noise, and a dedicated noise image is fed to some or all layers of the synthesis network. The noise image is broadcasted to all feature maps using learned per-feature scaling factors and then added to the output of the corresponding convolution, as illustrated in
As depicted in
In at least one embodiment, a GAN is trained from a data corpus, one can feed-in the CFD-generated, aerodynamic shape-optimized, car exterior outline shapes as input to the trained GAN, and obtain the filled-in car images with diverse styles. By choosing different random latent noise vectors, one can obtain different car colors, lighting conditions, wheel designs, and other attributes. Thus, at the end of the two-step process, one obtains car images whose shapes are not only aerodynamically shape-optimized, but also have aesthetic and/or stylish appeal to a potential customer. This joint methodology is a useful design tool in the development of the next-generation automobiles.
Alternative embodiments may be implemented as well. For example, in at least one other embodiment, the above two steps are reversed: that is, the GAN is first used to add styles to a corpus of car silhouette shapes, and a subset of the shapes that have an aesthetic appeal to the design engineers are short-listed for the CFD simulations in the second step. For example, a shortlist of the top 10, 20, 30, 40, 50, 100, etc. shapes may be identified by the GAN. Here, RANS simulations are undertaken and the shortlisted shapes that have the lowest aerodynamic drag coefficients are progressed to the next step in the design process.
In at least one embodiment, flowchart 500 depicts a step to select GAN design parameters 502. GAN design parameters may refer to inputs that are provided to a Generative Adversarial Network (GAN) such as a StyleGAN-based model that is trained to generate vehicle outline shapes from the design parameters. For example, a designer may select a parameter for a vehicle class such as sedan, SUV, etc. as a design parameter. In some embodiments, the design parameters can be used to specify various aspects of the shape to be designed. The design parameters may specify that the outline should include a shark fin for the vehicle, the location and/or height of the bumper, or other information that would otherwise specify one or more design constraints on the vehicle outline shapes that the GAN is being used to generate.
In at least one embodiment, flowchart 500 depicts a step to use generative adversarial network (GAN) 504 to generate a set of vehicle outline shapes 506. The vehicle shape outlines may be generated using a pre-trained network that learns how to produce the specified vehicle outline shapes from a training corpus 508 of vehicle images. For example, images of existing vehicles may be captured and stored for later use as the training corpus 508 to train a GAN. The GAN may be a Style-GAN based model. The GAN 504 may be implemented according to any suitable architecture, such as those described in connection with
In at least one embodiment, vehicle shape outlines 506 refer to the outlines of vehicles or other industrial applications. For example, the GAN may be used to generate shape outlines for various car parts rather than the vehicle as a whole, or may be used in other contexts, such as for airplane design or other industrial parts or applications that may be subject to multidisciplinary considerations including but not limited to aerodynamic considerations and aesthetic considerations. In various embodiments, GAN 504 generates a fixed number of outlines that can be specified by a user. For example, the user may specify to generate 5, 10, 15, 20, etc. different outlines based on a given set of design parameters.
In various embodiments, flowchart 500 comprises a step to assign style preference values 510. The style preferences for various shape outlines may be quantified using subject matter expert (SME) rules that are encoded in an evaluation function. The scores may be in any suitable range or denomination. The scores may be from 0 to 1, 0 to 10, 0 to 100, and so forth. In at least one embodiment, flowchart 500 comprises a step to select candidate shapes 512. In various embodiments, the set of vehicle outline shapes 506 are assigned style preference values and ranked or filtered based on their respective scores. In some embodiments, vehicle outline shapes with poor style preference values may be discarded. For example, vehicle outline shapes that fall below a certain threshold or are not within the top N scores may be discarded from consideration as candidates in downstream steps of flowchart 500.
In at least one embodiment, flowchart 500 comprises a step to use a Computational Fluid Dynamics (CFD) 514 to determine aerodynamic properties of the candidate shapes. For example, a set of candidate vehicle outline shapes may be selected and then CFD simulations may be used to determine the aerodynamic drag coefficients and so forth. In various embodiments, flowchart 500 comprises a step to map aerodynamic properties to performance metrics 516. For example, performance metrics (e.g., high drag coefficient) may be determined to determine an overall performance score of a vehicle outline shape that accounts for any and/or all simulated aerodynamic properties of the outline shape. This may involve the computation of a single value that encapsulates multiple simulated aerodynamic properties of the shape that may be determined by one of skill in the art.
In at least one embodiment, performance values and style values may be determined for each of the candidate shapes. In some embodiments, a Pareto front is explored by computing pairs of performance scores and style scores for each of the candidate shapes and determining an optimal or best design outline that accounts for desirable aerodynamics and desirable aesthetics. Optimum shapes may be identified by running an evolutionary search-based multi-objective optimization (MOO) process 518. For example, the performance and aesthetic scores may be normalized to a 1-to-10 scale and the aerodynamic and aesthetic values may be multiplied together to determine a score for MOO purposes. A few candidates near the optimum can be selected and one can build prototypes of these car shapes that satisfy the desired criteria 520. The desired criteria may be determined based on aerodynamic and/or aesthetic considerations, or any other suitable criteria for selection of vehicle design. Flowchart 500 depicts a step to create physical designs and/or test for aerodynamic performance 522. The physical design may be created based on the vehicle attributes and/or vehicle shape outline determined in previous steps. The aerodynamic performance of the physical designs may be measured to determine whether the expected aerodynamic properties matches the actual measured aerodynamic properties. In various embodiments, the flowchart 500 includes a step to track and/or update the GAN, CFD, performance models, or any combination thereof. A feedback mechanism may be used to iteratively refine various aspects of the flowchart 500.
In various embodiments, process 600 comprises a step to perform computational fluid dynamics (CFD) simulations to determine a set of vehicle outline shapes, wherein the CFD simulations are used to determine one or more aerodynamic properties of the set of vehicle outline shapes 602. In various embodiments, CDF simulations are used to determine various performance metrics of a proposed outline. In some embodiments, the set of vehicle outline shapes are selected based on aerodynamic drag coefficient determined by the CFD simulations. For example, the top N shapes may be selected as candidates, where N=1, 2, 3, 4, 5, 10, 15, 20, and various other suitable values. The number N may be a user-selectable configuration option.
In various embodiments, process 600 comprises a step to provide a first vehicle outline shape of the set of vehicle outline shapes as an input to a generative adversarial network (GAN) that is trained to learn aesthetic preferences for vehicle attributes 604. In various embodiments, set of vehicle attributes comprises at least: color, shape, and wheel design. In various embodiment, the GAN is further configured to receive a latent code as the input, in a first latent space, determine, based on a non-linear mapping network, an intermediate vector, in a second latent space, and provide the intermediate vector as an input to one or more affine transformations of a synthesis network that synthesizes an image based on the aesthetic preferences. The GAN may comprise a non-linear mapping network of 5-10 fully connected layers. Each layer of the synthesis network may be operable to receive per-channel scaling factors for Gaussian noise inputs. The GAN may comprise a synthesis network of 15-20 layers. The GAN may be a StyleGAN-based model.
In various embodiments, process 600 comprises a step to determine, by the GAN and based on the vehicle outline shape, a set of vehicle attributes 606. In various embodiments, set of vehicle attributes comprises at least: color, shape, and wheel design. The vehicle attributes may be represented in an image that is generated by the GAN.
In various embodiments, process 600 comprises a step to generate, by the GAN and based at least in part on the input, an image of a vehicle, wherein the vehicle depicted in the image has an outline that corresponds to the vehicle outline shape and has the set of vehicle attributes 608. In various embodiments, the system preforming process 600 is further configured to determine, for each respective vehicle outline shape of the set of vehicle outline shapes, a respective performance score and a respective style score, and determine a Pareto front based on the performance scores and the styles scores of the set of vehicle outline shapes.
In various embodiments, process 700 comprises a step to obtain a generative adversarial network (GAN) that is trained to learn aesthetic preferences for vehicle attributes 702. In various embodiments, the GAN is further configured to receive a latent code as the input, in a first latent space,
determine, based on a non-linear mapping network, an intermediate vector, in a second latent space, and provide the intermediate vector as an input to one or more affine transformations of a synthesis network that synthesizes an image based on the aesthetic preferences. The non-linear mapping network may comprises 5-10 fully connected layers. The synthesis network may comprises 15-20 layers. The intermediate vector may be provided as an input to affine transformation of the synthesis network. Each layer of the synthesis network may be operable to receive per-channel scaling factors for Gaussian noise inputs.
In various embodiments, process 700 comprises a step to determine, by the GAN, a plurality of vehicle images inferred to have at least a threshold level of aesthetic preference 704. In various embodiments, process 700 comprises a step to determine, based on the plurality of vehicle images, a corresponding plurality of vehicle outline shapes 706. In various embodiments, process 700 comprises a step to perform computational fluid dynamics (CFD) simulations to determine corresponding aerodynamic properties for the plurality of vehicle outline shapes 708.
Examples, as described herein, may include or may operate on logic or a number of components, modules, or mechanisms. Modules are tangible entities (e.g., hardware) capable of performing specified operations when operating. A module includes hardware. In an example, the hardware may be specifically configured to carry out a specific operation (e.g., hardwired). In another example, the hardware may include configurable execution units (e.g., transistors, circuits, etc.) and a computer readable medium containing instructions where the instructions configure the execution units to carry out a specific operation when in operation. The configuring may occur under the direction of the executions units or a loading mechanism. Accordingly, the execution units are communicatively coupled to the computer-readable medium when the device is operating. In this example, the execution units may be a member of more than one module. For example, under operation, the execution units may be configured by a first set of instructions to implement a first module at one point in time and reconfigured by a second set of instructions to implement a second module at a second point in time.
The machine (e.g., computer system) 800 may include any combination of the illustrated components. For example, the machine 800 may include a hardware processor 802 (e.g., a central processing unit (CPU), a graphics processing unit (GPU), a tensor processing unit (TPU) including an artificial intelligence application-specific integrated circuit (ASIC), a hardware processor core, or any combination thereof), a main memory 804 and a static memory 806, some or all of which may communicate with each other via an interlink (e.g., bus) 808. The machine 800 may further include a power management device 832, a graphics display device 810, an alphanumeric input device 812 (e.g., a keyboard), and a user interface (UI) navigation device 814 (e.g., a mouse). In an example, the graphics display device 810, alphanumeric input device 812, and UI navigation device 814 may be a touch screen display. The machine 800 may additionally include a storage device (i.e., drive unit) 816, a signal generation device 818 (e.g., a data signal), a network interface device/transceiver 820 coupled to antenna(s) 830, and one or more sensors 828, such as a sound detecting sensor (e.g., a microphone), accelerometers, magnetometers, location sensors, and the like. The machine 800 may include an output controller 834, such as a serial (e.g., universal serial bus (USB), parallel, or other wired or wireless (e.g., infrared (IR), near field communication (NFC), etc.) connection to communicate with or control one or more peripheral devices (e.g., a printer, a card reader, other sensors, etc.)).
The storage device 816 may include a machine readable medium 822 on which is stored one or more sets of data structures or instructions 824 (e.g., software) embodying or utilized by any one or more of the techniques or functions described herein. The instructions 824 may also reside, completely or at least partially, within the main memory 804, within the static memory 806, or within the hardware processor 802 during execution thereof by the machine 800. In an example, one or any combination of the hardware processor 802, the main memory 804, the static memory 806, or the storage device 816 may constitute machine-readable media.
While the machine-readable medium 822 is illustrated as a single medium, the term “machine-readable medium” may include a single medium or multiple media (e.g., a centralized or distributed database, and/or associated caches and servers) configured to store the one or more instructions 824.
Various embodiments may be implemented fully or partially in software and/or firmware. This software and/or firmware may take the form of instructions contained in or on a non-transitory computer-readable storage medium. Those instructions may then be read and executed by one or more processors to enable performance of the operations described herein. The instructions may be in any suitable form, such as but not limited to source code, compiled code, interpreted code, executable code, static code, dynamic code, and the like. Such a computer-readable medium may include any tangible non-transitory medium for storing information in a form readable by one or more computers, such as but not limited to read only memory (ROM); random access memory (RAM); magnetic disk storage media; optical storage media; a flash memory, etc.
The term “machine-readable medium” may include any medium that is capable of storing, encoding, or carrying instructions for execution by the machine 800 and that cause the machine 800 to perform any one or more of the techniques of the present disclosure, or that is capable of storing, encoding, or carrying data structures used by or associated with such instructions. Non-limiting machine-readable medium examples may include solid-state memories and optical and magnetic media. In an example, a massed machine-readable medium includes a machine-readable medium with a plurality of particles having resting mass. Specific examples of massed machine-readable media may include non-volatile memory, such as semiconductor memory devices (e.g., electrically programmable read-only memory (EPROM), or electrically erasable programmable read-only memory (EEPROM)) and flash memory devices; magnetic disks, such as internal hard disks and removable disks; magneto-optical disks; and CD-ROM and DVD-ROM disks.
The instructions 824 may further be transmitted or received over a communications network 826 using a transmission medium via the network interface device/transceiver 820 utilizing any one of a number of transfer protocols (e.g., frame relay, internet protocol (IP), transmission control protocol (TCP), user datagram protocol (UDP), hypertext transfer protocol (HTTP), etc.). Example communications networks may include DOCSIS, fiber optic, a local area network (LAN), a wide area network (WAN), a packet data network (e.g., the Internet), mobile telephone networks (e.g., cellular networks), plain old telephone (POTS) networks, wireless data networks (e.g., Institute of Electrical and Electronics Engineers (IEEE) 802.11 family of standards known as Wi-Fi®, IEEE 802.16 family of standards known as WiMax®), IEEE 802.15.4 family of standards, and peer-to-peer (P2P) networks, among others. In an example, the network interface device/transceiver 820 may include one or more physical jacks (e.g., Ethernet, coaxial, or phone jacks) or one or more antennas to connect to the communications network 826. In an example, the network interface device/transceiver 820 may include a plurality of antennas to wirelessly communicate using at least one of single-input multiple-output (SIMO), multiple-input multiple-output (MIMO), or multiple-input single-output (MISO) techniques. The term “transmission medium” shall be taken to include any intangible medium that is capable of storing, encoding, or carrying instructions for execution by the machine 800 and includes digital or analog communications signals or other intangible media to facilitate communication of such software.
The operations and processes described and shown above may be carried out or performed in any suitable order as desired in various implementations. Additionally, in certain implementations, at least a portion of the operations may be carried out in parallel. Furthermore, in certain implementations, less than or more than the operations described may be performed.
The word “exemplary” is used herein to mean “serving as an example, instance, or illustration.” Any embodiment described herein as “exemplary” is not necessarily to be construed as preferred or advantageous over other embodiments. The terms “computing device,” “user device,” “communication station,” “station,” “handheld device,” “mobile device,” “wireless device” and “user equipment” (UE) as used herein refers to a wireless communication device such as a cable box, a wearable smart device, cellular telephone, a smartphone, a tablet, a netbook, a wireless terminal, a laptop computer, a femtocell, a high data rate (HDR) subscriber station, an access point, a printer, a point of sale device, an access terminal, or other personal communication system (PCS) device. The device may be either mobile or stationary.
As used within this document, the term “communicate” is intended to include transmitting, or receiving, or both transmitting and receiving. This may be particularly useful in claims when describing the organization of data that is being transmitted by one device and received by another, but only the functionality of one of those devices is required to infringe the claim. Similarly, the bidirectional exchange of data between two devices (both devices transmit and receive during the exchange) may be described as “communicating,” when only the functionality of one of those devices is being claimed. The term “communicating” as used herein with respect to a wireless communication signal includes transmitting the wireless communication signal and/or receiving the wireless communication signal. For example, a wireless communication unit, which is capable of communicating a wireless communication signal, may include a wireless transmitter to transmit the wireless communication signal to at least one other wireless communication unit, and/or a wireless communication receiver to receive the wireless communication signal from at least one other wireless communication unit.
As used herein, unless otherwise specified, the use of the ordinal adjectives “first,” “second,” “third,” etc., to describe a common object, merely indicates that different instances of like objects are being referred to and are not intended to imply that the objects so described must be in a given sequence, either temporally, spatially, in ranking, or in any other manner.
Some embodiments may be used in conjunction with various devices and systems, for example, a wearable smart device, a personal computer (PC), a desktop computer, a mobile computer, a laptop computer, a notebook computer, a tablet computer, a server computer, a handheld computer, a handheld device, a personal digital assistant (PDA) device, a handheld PDA device, an on-board device, an off-board device, a hybrid device, a vehicular device, a non-vehicular device, a mobile or portable device, a consumer device, a non-mobile or non-portable device, a wireless communication station, a wireless communication device, a wireless access point (AP), a wired or wireless router, a wired or wireless modem, a video device, an audio device, an audio-video (A/V) device, a wired or wireless network, a wireless area network, a wireless video area network (WVAN), a local area network (LAN), a wireless LAN (WLAN), a personal area network (PAN), a wireless PAN (WPAN), and the like.
Some embodiments may be used in conjunction with one way and/or two-way radio communication systems, cellular radio-telephone communication systems, a mobile phone, a cellular telephone, a wireless telephone, a personal communication system (PCS) device, a PDA device which incorporates a wireless communication device, a mobile or portable global positioning system (GPS) device, a device which incorporates a GPS receiver or transceiver or chip, a device which incorporates an RFID element or chip, a multiple input multiple output (MIMO) transceiver or device, a single input multiple output (SIMO) transceiver or device, a multiple input single output (MISO) transceiver or device, a device having one or more internal antennas and/or external antennas, digital video broadcast (DVB) devices or systems, multi-standard radio devices or systems, a wired or wireless handheld device, e.g., a smartphone, a wireless application protocol (WAP) device, or the like.
Some embodiments may be used in conjunction with one or more types of wireless communication signals and/or systems following one or more wireless communication protocols, for example, DOCSIS, radio frequency (RF), infrared (IR), frequency-division multiplexing (FDM), orthogonal FDM (OFDM), time-division multiplexing (TDM), time-division multiple access (TDMA), extended TDMA (E-TDMA), general packet radio service (GPRS), extended GPRS, code-division multiple access (CDMA), wideband CDMA (WCDMA), CDMA 2000, single-carrier CDMA, multi-carrier CDMA, multi-carrier modulation (MDM), discrete multi-tone (DMT), Bluetooth®, global positioning system (GPS), Wi-Fi, Wi-Max, ZigBee, ultra-wideband (UWB), global system for mobile communications (GSM), 2G, 2.5G, 3G, 3.5G, 4G, fifth generation (5G) mobile networks, 3GPP, long term evolution (LTE), LTE advanced, enhanced data rates for GSM Evolution (EDGE), or the like. Other embodiments may be used in various other devices, systems, and/or networks.
Embodiments according to the disclosure are in particular disclosed in the attached claims directed to a method, a storage medium, a device and a computer program product, wherein any feature mentioned in one claim category, e.g., method, can be claimed in another claim category, e.g., system, as well. The dependencies or references back in the attached claims are chosen for formal reasons only. However, any subject matter resulting from a deliberate reference back to any previous claims (in particular multiple dependencies) can be claimed as well, so that any combination of claims and the features thereof are disclosed and can be claimed regardless of the dependencies chosen in the attached claims. The subject-matter which can be claimed comprises not only the combinations of features as set out in the attached claims but also any other combination of features in the claims, wherein each feature mentioned in the claims can be combined with any other feature or combination of other features in the claims. Furthermore, any of the embodiments and features described or depicted herein can be claimed in a separate claim and/or in any combination with any embodiment or feature described or depicted herein or with any of the features of the attached claims.
The foregoing description of one or more implementations provides illustration and description, but is not intended to be exhaustive or to limit the scope of embodiments to the precise form disclosed. Modifications and variations are possible in light of the above teachings or may be acquired from practice of various embodiments.
Certain aspects of the disclosure are described above with reference to block and flow diagrams of systems, methods, apparatuses, and/or computer program products according to various implementations. It will be understood that one or more blocks of the block diagrams and flow diagrams, and combinations of blocks in the block diagrams and the flow diagrams, respectively, may be implemented by computer-executable program instructions. Likewise, some blocks of the block diagrams and flow diagrams may not necessarily need to be performed in the order presented, or may not necessarily need to be performed at all, according to some implementations.
These computer-executable program instructions may be loaded onto a special-purpose computer or other particular machine, a processor, or other programmable data processing apparatus to produce a particular machine, such that the instructions that execute on the computer, processor, or other programmable data processing apparatus create means for implementing one or more functions specified in the flow diagram block or blocks. These computer program instructions may also be stored in a computer-readable storage media or memory that may direct a computer or other programmable data processing apparatus to function in a particular manner, such that the instructions stored in the computer-readable storage media produce an article of manufacture including instruction means that implement one or more functions specified in the flow diagram block or blocks. As an example, certain implementations may provide for a computer program product, comprising a computer-readable storage medium having a computer-readable program code or program instructions implemented therein, said computer-readable program code adapted to be executed to implement one or more functions specified in the flow diagram block or blocks. The computer program instructions may also be loaded onto a computer or other programmable data processing apparatus to cause a series of operational elements or steps to be performed on the computer or other programmable apparatus to produce a computer-implemented process such that the instructions that execute on the computer or other programmable apparatus provide elements or steps for implementing the functions specified in the flow diagram block or blocks.
Accordingly, blocks of the block diagrams and flow diagrams support combinations of means for performing the specified functions, combinations of elements or steps for performing the specified functions and program instruction means for performing the specified functions. It will also be understood that each block of the block diagrams and flow diagrams, and combinations of blocks in the block diagrams and flow diagrams, may be implemented by special-purpose, hardware-based computer systems that perform the specified functions, elements or steps, or combinations of special-purpose hardware and computer instructions.
Implementations of the systems, apparatuses, devices, and methods disclosed herein may comprise or utilize a special purpose or general-purpose computer including computer hardware, such as, for example, one or more processors and system memory, as discussed herein. Computer-executable instructions comprise, for example, instructions and data which, when executed at a processor, cause a general-purpose computer, special purpose computer, or special purpose processing device to perform a certain function or group of functions. An implementation of the devices, systems and methods disclosed herein may communicate over a computer network. A “network” is defined as one or more data links that enable the transport of electronic data between computer systems and/or modules and/or other electronic devices.
Although the subject matter has been described in language specific to structural features and/or methodological acts, it is to be understood that the subject matter defined in the appended claims may not necessarily be limited to the described features or acts described above. Rather, the described features and acts are disclosed as example forms of implementing the claims.
While various embodiments of the present disclosure have been described above, it should be understood that they have been presented by way of example only, and not limitation. It will be apparent to persons skilled in the relevant art that various changes in form and detail can be made therein without departing from the spirit and scope of the present disclosure. Thus, the breadth and scope of the present disclosure should not be limited by any of the above-described exemplary embodiments but should be defined only in accordance with the following claims and their equivalents. The foregoing description has been presented for the purposes of illustration and description. It is not intended to be exhaustive or to limit the present disclosure to the precise form disclosed. Many modifications and variations are possible in light of the above teaching. Further, it should be noted that any or all of the aforementioned alternate implementations may be used in any combination desired to form additional hybrid implementations of the present disclosure. For example, any of the functionality described with respect to a particular device or component may be performed by another device or component. Conditional language, such as, among others, “can,” “could,” “might,” or “may,” unless specifically stated otherwise, or otherwise understood within the context as used, is generally intended to convey that certain embodiments could include, while other embodiments may not include, certain features, elements, and/or steps. Thus, such conditional language is not generally intended to imply that features, elements, and/or steps are in any way required for one or more embodiments.