Numerous system and techniques are available to measure observable quantities over time. From ultrafast optical spectroscopy to longitudinal studies of geological formations, monitoring an observable quantity can be accomplished generally reliably. Even in complex systems (such as systems that present chaos or include other types of stochastic phenomena) having multiple relationships between quantities that determine observable phenomena, an observable quantity usually is available and can be probed. Yet, such complexity hinders the generation of realistic time series of an observable quantity, rendering such task difficult, if not plainly unfeasible. Therefore, much remains to be improved in the generation of time series.
The accompanying drawings are an integral part of the disclosure and are incorporated into the present specification. The drawings, which are not drawn to scale, illustrate example embodiments of the disclosure and, in conjunction with the description and claims, serve to explain at least in part various principles, features, or aspects of the disclosure. Some embodiments of the disclosure are described more fully below with reference to the accompanying drawings. However, various aspects of the disclosure can be implemented in many different forms and should not be construed as being limited to the implementations set forth herein. Like numbers refer to like, but not necessarily the same or identical, elements throughout.
The disclosure recognizes and addresses, in at least some embodiments, the issue of generation of time series. Embodiments of the disclosure include systems, techniques, and computer-program products that, individually and/or in combination, permit or otherwise facilitate generating time series using generative adversarial networks. As is described in greater detail below, the disclosure provides, amongst other things, generative adversarial networks (GANs) that generate realistic real-valued multi-dimensional time series. A GAN includes emerging artificial intelligence processes for both semi-supervised and unsupervised machine learning, through implicitly modeling a distribution of high-dimensional data. More particularly, the GAN includes a generator neural network and a discriminator neural network. The generator neural network can be embodied in or can include, for example, a deconvolutional neural network. The discriminator neural network can be embodied in or can include, for example, a convolutional neural network. Rather than relying on backpropagation, the disclosure utilizes an unsupervised approach to train a GAN to generate a time series. Specifically, embodiments of the disclosure apply adversarial training to observed time series (or time series data) in order to configure the GAN to generate a synthetic time series. Performance of GANs in accordance with aspects of this disclosure is illustrated by comparing observed time series in an industrial machine with synthetic time series generated with a trained GAN of this disclosure.
With reference to the drawings,
In one example, the generator network module can create a synthetic time series 114 from random noise data 104 in an attempt to generate a realistic time series. The discriminator network module can receive the synthetic time series 114 and observed time series data 118, and can attempt to distinguish them. The discriminator network module 120 can identify a synthetic time series with a probability p 130.
The generator neural network and the discriminator neural network can be trained simultaneously, for their respective goals, to achieve Nash equilibrium. More specifically, the goal of the generator neural network is to learn to map from a latent space (random noise) to the data distribution of observed time series of an observable quantity (e.g., physical property). The discriminator neural network can discriminate between samples from the observed data distribution and synthetic time series produced by the generator neural network, as implemented by the generator network module. The training objective of the generator neural network is to deceive the discriminator neural network by producing synthetic time series that appear to be drawn from the observed data distribution of observed time series. Stated similarly, the goal of the generator neural network is to increase the error rate of the discriminator neural network.
In some embodiments, as is illustrated in
A group of sensor devices can be integrated into or otherwise coupled to the hardware 214 to collect data indicative or otherwise representative of an operational state of the industrial machine 210. In some embodiments, the group of sensor devices can be homogeneous, including several sensor devices of a same type (e.g., pressure meters, temperature meters, or another type of sensor device). In other embodiments, the group of sensor devices can be heterogeneous, where a first subset of the group of sensor devices corresponds to sensor devices of a first type and a second subset of the group of sensor devices corresponds to sensor devices of a second type. For instance, such a group of sensor devices can include pressure meter(s) and temperature meter(s). As is illustrated in
Each sensor device of the group of sensor devices 2181-218D can supply (e.g., generate and send) output data indicative or otherwise representative of magnitude of a physical property probed by the sensor device. Generation of a datum corresponds to a measurement of the sensor device. The data can be generated at defined times over a defined interval or several defined intervals. A time interval can correspond, for example, to a measurement run (or an experiment). For instance, that data can be generated in nearly real time, periodically, according to a schedule, or in response to polling by an external device. Thus, the data can form a time series that can be sent, for example, to one or more memory devices 270 (generically referred to as observed time series data 270).
Therefore, in one embodiment, the time series 118 (shown in
With further reference to
The configuration module 314 can configure a discriminator network having almost any number of layers of units (e.g., three layers, four layers, five layers, or the like). In some embodiments, the configuration module 314 configures a discriminator network having five layers, which for the sake of nomenclature, are labeled as d1, d2, d3, d4, and d5.
As is further illustrated in
The discriminator neural network further includes a third layer, e.g., d3, having a dimension in feature space equal to 16×6×64. The third layer is a convolution layer (4, 1, 32, 64) and applies Leaky ReLU activation. In some instances, a slope of leak in the Leaky ReLU can be configured to 0.2. Each one of the second layer and the third layer utilizes batch normalization, where the input to each unit in the convolution layer is normalized to have zero mean and unit variance. Batch normalization can stabilize learning.
The discriminator neural network further includes a fourth layer, e.g., d4, having a dimension has a dimension in feature space equal to 1024. The fourth layer is a multilayer perceptron (MLP) layer that is flattened (indicated as “Flatten” in
With further reference to
More specifically, in some embodiments, the configuration module 314 configures a generator network having five layers, which for the sake of nomenclature, are labeled as g1, g2, g3, g4, and g5.
As is further illustrated in
The generator neural network need not be configured with a same number of layers than the discriminator network has. In some embodiments, as is illustrated in
With further reference to
The objective function to train the GAN configured by the configuration module 314 is denoted as V (, ). Here, again, is a differentiable function that represents the generator network and is another differentiable function that represents the discriminator network.
The optimization problem that is solved to train such a GAN is defined as follows:
Here, x represents a multi-dimensional vector of observed values (measurements), e.g., an observed time series, and z represents a multi-dimensional vector of uniformly distributed random values or another type of noise values. Further, p9 (⋅) represents the probability distribution of synthetic data, e.g., a synthetic time series, and pd(x) represents the probability distribution of observed data. In some embodiments, explicit expressions for such distributions are unavailable and a numeric computation can be implemented. Furthermore, p(⋅)(⋅) represents the expectation operator for the probability distribution p(⋅).
The time series generation system 310 includes an optimization module 318 that can implement adversarial training in order to determine an adequate GAN, as is disclosed herein. Without intending to be bound by theory, it is noted that adversarial attempts to force pg(x) to be equal to pd(x). For a specific generator, there is a unique optimal discriminator:
Therefore, the generator consistent with *(x) is optimal when pg(x)=pd(x), implying that the optimal discriminator predicts 0.5 for all samples drawn from x.
The optimization module 318 can solve the optimization problem in Eq. (1) by jointly minimizing the objective function V() with respect to and maximizing V() with respect to . As such, the optimization module 318 can alternatingly update the first group of parameters that defines and the second group of parameters that define until a convergence criterion is satisfied, resulting in a satisfactory and a satisfactory . More concretely, in some embodiments, the optimization module 318 can solve the optimization problem posed by Eq. (1) by performing a stochastic gradient descent (SGD) process. In one example, the SGD process can include mini-batch SGD, with a mini-batch size equal to 128. In one example, performance of the SGD process can implement a first-order gradient-based optimization of the objective function V() based on adaptive estimates of lower-order moments. The learning rate in such a process can be configured to 0.0002, and first and second hyper-parameters to control exponential decay rates can be configured at 0.500 and 0.999, respectively. Initial first weights in the discriminator neural network and initial second weights in the generator neural network can be initialized according to a uniform probability distribution that has a zero mean and a defined variance that depends on the inverse of a number of units linked to the weights being initialized.
The time series generation system 310 can include one or more memory devices 328 that can retain various parameters (referred to as optimization parameters 328) that define, amongst other things, the stochastic gradient descent process. Such parameters can be retained within data structures referred to as model parameters, and can include a learning rate, slope of leak in Leaky ReLU, initial values of weights for each layer in the discriminator network and each layer in the generator network, and the like, in accordance with aspects described herein.
In some embodiments, the optimization module 318 can iteratively update the discriminator (e.g., perform changes to the parameters that define the discriminator) by ascending the stochastic gradient of the objective function V(), while maintaining unchanged the parameters that define the generator . In a subsequent iteration, the optimization module 318 can update the generator (e.g., perform changes to the parameters that define the generator) by descending the stochastic gradient of the objective function V(). To evaluate the objective function, the optimization module 318 can access observed time series data from the memory device(s) 270 and can apply a current discriminator and generator to the accessed time series data.
After consecutive updates of the discriminator and the generator, the optimization module 318 can determine if a next iteration is to be implemented. To that point, the optimization module can evaluate if current parameters yield a change in V() that satisfies a convergence criterion. In response to ascertaining the convergence criterion is satisfied, the optimization module 318 can terminate the SGD process.
As mentioned solving the optimization problem in Eq. (1) trains a GAN, resulting in satisfactory parameters (e.g., parameters obtained after convergence of the of iterative SGD process) that define the discriminator network and the generator network. Upon or after the optimization problem is solved, the optimization module 318 can retain the satisfactory parameters in one or more memory devices 338, within data structures referred to as model parameters 338.
The processor(s) 360 can be functionally coupled to the memory 370 by means of a communication architecture 365. The communication architecture 365 is suitable for the particular arrangement (localized or distributed) of the processor(s) 360. As such, the communication architecture 365 can include base station devices; router devices; switch devices; server devices; aggregator devices; bus architectures; a combination of the foregoing; or the like.
In the illustrated computing system 350, the time series generation system 310 can be embodied in or can include machine-accessible instructions (e.g., computer-readable and/or computer-executable instructions) that can be accessed and executed by at least one of the processor(s) 360. The processor(s) 350 can execute the time series generation system 310 to cause the computing system to generate synthetic time series using a GAN as is disclosed herein. Similarly, the memory 370 also can retain or otherwise store the observed time series data 270.
The time series generation system 310 includes a GAN module 324 that can utilize or otherwise leverage model parameters to generate time series data using an optimized generator function (opt).
As it can be gleaned from
In view of various aspects described herein, examples of methods that can be implemented in accordance with this disclosure can be better appreciated with reference to
In some embodiments, one or several of the exemplified methods and/or other techniques disclosed herein can be represented as a series of interrelated states or events, such as in a state-machine diagram. Other representations also are possible. For example, interaction diagram(s) can represent an exemplified method and/or a technique in accordance with this disclosure in scenarios in which different entities perform different portions of the disclosed methodologies.
It should be further appreciated that the example methods disclosed in this specification can be retained or otherwise stored on an article of manufacture (such as a computer-program product) in order to permit or otherwise facilitate transporting and transferring such example methods to computers for execution, and thus implementation, by processor(s) or for storage in a memory.
Methods disclosed throughout the subject specification and annexed drawings are capable of being stored on an article of manufacture to facilitate transporting and transferring such methodologies to computers or other types of information processing machines or processing circuitry for execution, and thus implementation by a processor or for storage in a memory device or another type of computer-readable storage device. In one example, one or more processors that perform a method or combination of methods disclosed herein can be utilized to execute programming code instructions retained in a memory device or any computer-readable or machine-readable storage device or non-transitory storage media, to implement one or several of the exemplified methods and/or other techniques disclosed herein. The programming code instructions, when executed by the one or more processors can implement or carry out the various operations in the exemplified methods and/or other technique disclosed herein.
The programming code instructions, therefore, provide a computer-executable or machine-executable framework to implement the exemplified methods and/or other techniques disclosed herein. More specifically, yet not exclusively, each block of the flowchart illustrations and/or combinations of blocks in the flowchart illustrations can be implemented by the programming code instructions.
At block 1210 the computing system can configure a first neural network having a first function representative of an output of the first neural network. In some embodiments, the first neural network can embody a discriminator network and, thus, the first function can be embodied in disclosed hereinbefore. In one aspect, configuring the first neural network can include configuring a deconvolutional neural network having multiple layers (e.g., three layers, four layers, five layers, or the like), each layer including a respective set of operations (see, e.g.,
At block 1220 the computing system can configure a second neural network having a second function representative of an output of the second neural network. In the embodiments referred to above in connection with block 1110, the second neural network can be embodied in a generator network. As such, the second function can be embodied in disclosed hereinbefore. In one aspect, configuring the second neural network can include configuring a convolutional neural network having multiple layers (e.g., three layers, four layers, five layers, or the like), each layer including a respective set of operations (see, e.g.,
In one embodiment, the second neural network has a same number of layers as the first neural network. Again, the disclosure is not so limited and the number of layers in the second neural network can different from the number of layers in the first neural network.
At block 1230, the computing system can generate a GAN by solving an optimization problem with respect to an objective function based at least on the first function (e.g., ) and the second function (e.g., ). In some embodiments, the optimization problem can correspond to the optimization problem posed in Eq. (1). To solve the optimization problem, the computing system can jointly minimize the objective function with respect to the second function and maximize the objective function with respect to the first function. In some aspects, as is disclosed herein, jointly minimizing the objective function can include updating alternatingly the first function and the second function until a convergence criterion is satisfied, resulting in a satisfactory first function and a satisfactory second function. More specifically, as is disclosed herein, the computing system can iteratively update the first function (e.g., perform changes to the parameters that define the first function) by ascending the stochastic gradient of the objective function, while maintaining unchanged the parameters that define the second function. In a subsequent iteration, the computing system can update the second function (e.g., perform changes to the parameters that define the second function) by descending the stochastic gradient of the objective function. The computing system can evaluate a convergence criterion after each iteration including an update to the first function and an update to the second function. The computing system can terminate such alternating updates in response to the criterion being satisfied.
At block 1240, the computing system can generate a time series using at least the generator neural network. For example, the computing system can generate one or more of the time series illustrated in
The example operational environment 1300 or portions thereof can embody or can constitute other ones of the various operational environments and systems described hereinbefore. As such, the computing device 1310, individually or combination with at least one of the computing device(s) 1370), can embody or can constitute the time series generation system 310 described herein.
The computational environment 1300 represents an example implementation of the various aspects or elements of the disclosure in which the processing or execution of operations described in connection with generation of synthetic time series in accordance with aspects disclosed herein can be performed in response to execution of one or more software components at the computing device 1310. Such one or more software components render the computing device 1310 (or any other computing device that contains the software component(s) a particular machine for generating synthetic time series using a GAN, in accordance with aspects described herein, among other functional purposes.
A software component can be embodied in or can include one or more computer-accessible instructions (e.g., computer-readable and/or computer-executable instructions). In some embodiments, as mentioned, at least a portion of the computer-accessible instructions can be executed to perform at least a part of one or more of the example methods (e.g., method 1200 illustrated in
For instance, to embody one such method, at least the portion of the computer-accessible instructions can be retained in a computer-readable storage non-transitory medium and executed by one or more processors (e.g., at least one of processor(s) 1314). The one or more computer-accessible instructions that embody or otherwise constitute a software component can be assembled into one or more program modules, for example. Such program module(s) can be compiled, linked, and/or executed (by one or more of the processor(s) 1314) at the computing device 1310 or other computing devices.
Further, such program module(s) can include computer code, routines, programs, objects, components, information structures (e.g., data structures and/or metadata structures), etc., that can perform particular tasks (e.g., one or more operations) in response to execution by one or more processors. At least one of such processor(s) can be integrated into the computing device 1310. For instance, the one or more processor that can execute the program module(s) can be embodied in or can include a non-empty subset the processor(s) 1314. In addition, at least another one of the processor(s) can be functionally coupled to the computing device 1310.
The various example embodiments of the disclosure can be operational with numerous other general purpose or special purpose computing system environments or configurations. Examples of well-known computing systems, environments, and/or configurations that can be suitable for implementation of various aspects or elements of the disclosure in connection with generation of synthetic time series in accordance with aspects of this disclosure can include personal computers; server computers; laptop devices; handheld computing devices, such as mobile tablets or e-readers; wearable computing devices; and multiprocessor systems. Additional examples can include, programmable consumer electronics, network personal computers (PCs), minicomputers, mainframe computers, blade computers, programmable logic controllers, distributed computing environments that comprise any of the above systems or devices, and the like.
As is illustrated in
In some embodiments, the computing device 1310 can include, optionally, a radio unit 1312. The radio unit 1312 can include one or more antennas and a communication processing unit that can permit wireless communication between the computing device 1310 and another device, such as one of the computing device(s) 1370 or a sensor device.
The I/O interface(s) 1316 can permit or otherwise facilitate communication of information between the computing device 1310 and an external device, such as another computing device (e.g., a network element or an end-user device) or a sensor device. Such communication can include direct communication or indirect communication, such as the exchange of information between the computing device 1310 and the external device via a network or elements thereof. In some embodiments, as is illustrated in
At least one of the network adapter(s) 1318 can functionally couple the computing device 1310 to one or more computing devices 1370 via one or more communication links (wireless, wireline, or a combination thereof) and one or more networks 1380 that, individually or in combination, can permit or otherwise facilitate the exchange of information (data, metadata, and/or signaling) between the computing device 1310 and the one or more computing devices 1370. Such network coupling provided at least in part by the at least one of the network adapter(s) 1318 can be implemented in a wired environment, a wireless environment, or both. The network(s) 1380 can include several types of network elements, including base stations; router devices; switch devices; server devices; aggregator devices; bus architectures; a combination of the foregoing; or the like. The network elements can be assembled to form a local area network (LAN), a metropolitan area network (MAN), a wide area network (WAN), and/or other networks (wireless or wired) having different footprints.
Information that is communicated by at least one of the network adapter(s) 1318 can result from the implementation of one or more operations of a method (or technique) in accordance with aspects of this disclosure. Such output can be any form of visual representation, including textual, graphical, animation, audio, haptic, and the like. In some scenarios, each one of the computing device(s) 1370 can have substantially the same architecture as the computing device 1310. In addition or in the alternative, the display unit(s) 1326 can include functional elements (e.g., lights, such as light-emitting diodes; a display, such as a liquid crystal display (LCD), a plasma monitor, a light-emitting diode (LED) monitor, or an electrochromic monitor; combinations thereof; or the like) that can permit or otherwise facilitate control of the operation of the computing device 1310, or can permit conveying or revealing the operational conditions of the computing device 1310.
In one aspect, the bus architecture 1332 represents one or more of several possible types of bus structures, including a memory bus or a memory controller, a peripheral bus, an accelerated graphics port, and a processor or local bus using any of a variety of bus architectures. As an illustration, such architectures can include an Industry Standard Architecture (ISA) bus, a Micro Channel Architecture (MCA) bus, an Enhanced ISA (EISA) bus, a Video Electronics Standards Association (VESA) local bus, an Accelerated Graphics Port (AGP) bus, a Peripheral Component Interconnect (PCI) bus, a PCI-Express bus, a Personal Computer Memory Card International Association (PCMCIA) bus, a Universal Serial Bus (USB), and the like.
The bus architecture 1332, and all other bus architectures described herein can be implemented over a wired or wireless network connection and each of the subsystems, including the processor(s) 1314, the memory 1330 and memory elements therein, and the I/O interface(s) 1316 can be contained within one or more remote computing devices 1370 at physically separate locations, connected through buses of this form, in effect implementing a fully distributed system.
In some embodiments, such a distributed system can implement the functionality described herein in a client-host or client-server configuration in which the time series generation modules 1336 or the time series generation information 1340, or both, can be distributed between the computing device 1310 and at least one of the computing device(s) 1370, and the computing device 1310 and at least one of the computing device(s) 1370 can execute such modules and/or leverage such information.
The computing device 1310 can include a variety of computer-readable media. Computer-readable media can be any available media (transitory and non-transitory) that can be accessed by the computing device 1310. In one aspect, computer-readable media can include computer non-transitory storage media (or computer-readable non-transitory storage media) and communications media. Example computer-readable non-transitory storage media can include, for example, both volatile media and non-volatile media, and removable and/or non-removable media. In one aspect, the memory 1330 can include computer-readable media in the form of volatile memory, such as random access memory (RAM), and/or non-volatile memory, such as read-only memory (ROM).
As is illustrated in
In one scenario, execution of at least one component of the time series generation modules 1336 can implement one or more of the techniques disclosed herein, such as the example method 1200. For instance, such execution can cause a processor (e.g., one of the processor(s) 1314) that executes the at least one component to carry out a disclosed example method or another technique of this disclosure.
It is noted that, in one aspect, a processor of the processor(s) 1314 that executes at least one of the time series generation modules 1336 can retrieve information from or retain information in one or more memory elements 1340 in the functionality information storage 1338 in order to operate in accordance with the functionality programmed or otherwise configured by the time series generation modules 1336. The one or more memory elements 1340 can be generically referred to as time series generation information 1340. Such information can include at least one of code instructions, information structures, or the like. For instance, at least a portion of such information structures can be indicative or otherwise representative of optimization parameters (e.g., optimization parameters 328); model parameters (e.g., model parameters 338); observed time series (e.g., observed time series 270); synthetic time series; a combination thereof; and the like, in accordance with aspects described herein.
In some embodiments, one or more of the time series generation modules 1336 can embody or can constitute, for example, the modules included in the time series generation system 310; namely, configuration module 314, optimization module 318, and/or generative adversarial network module 324 in accordance with aspects of this disclosure.
At least one of the one or more interfaces 1350 (e.g., application programming interface(s)) can permit or otherwise facilitate communication of information between two or more modules within the functionality instructions storage 1334. The information that is communicated by the at least one interface can result from implementation of one or more operations in a method of the disclosure. In some embodiments, one or more of the functionality instructions storage 1334 and the functionality information storage 1338 can be embodied in or can comprise removable/non-removable, and/or volatile/non-volatile computer storage media.
At least a portion of at least one of the time series generation modules 1336 or the timer series generation information 1340 can program or otherwise configure one or more of the processors 1314 to operate at least in accordance with the functionality disclosed herein to generate synthetic time series using at least a generative adversarial network. One or more of the processor(s) 1314 can execute at least one of the time series generation modules 1336 and leverage at least a portion of the information in the functionality information storage 1338 in order to provide management of calls from unknown callers in accordance with one or more aspects described herein.
It is noted that, in some embodiments, the functionality instructions storage 1334 can embody or can comprise a computer-readable non-transitory storage medium having computer-accessible instructions that, in response to execution, cause at least one processor (e.g., one or more of the processor(s) 1314) to perform a group of operations comprising the operations or blocks described in connection with the example method 1200 and other techniques disclosed herein.
The memory 1330 also can include computer-accessible instructions and information (e.g., data, metadata, and/or programming code instructions) that permit or otherwise facilitate the operation and/or administration (e.g., upgrades, software installation, any other configuration, or the like) of the computing device 1310. Accordingly, as is illustrated, the memory 1330 includes a memory element 1342 (labeled operating system (OS) instructions 1342) that contains one or more program modules that embody or include one or more operating systems, such as Windows operating system, Unix, Linux, Symbian, Android, Chromium, and substantially any OS suitable for mobile computing devices or tethered computing devices. In one aspect, the operational and/or architectural complexity of the computing device 1310 can dictate a suitable OS.
The memory 1330 further includes a system information storage 1346 having data, metadata, and/or programming code (e.g., firmware) that can permit or otherwise can facilitate the operation and/or administration of the computing device 1310. Elements of the OS instructions 1342 and the system information storage 1346 can be accessible or can be operated on by at least one of the processor(s) 1314.
While the functionality instructions storage 1334 and other executable program components (such as the OS instructions 1342) are illustrated herein as discrete blocks, such software components can reside at various times in different memory components of the computing device 1310 and can be executed by at least one of the processor(s) 1314. In certain scenarios, an implementation of the time series generation 1336 can be retained on or transmitted across some form of computer-readable media.
As is illustrated in
In addition, as is illustrated the communication links can be assembled in a first group of communication links 1374 and a second group of communication links 1372. Each one of the communication links in both groups can include one of an upstream link (or uplink (UL)) or a downstream link (or downlink (DL)). Each one of the UL and the DL can be embodied in or can include wireless links (e.g., deep-space wireless links and/or terrestrial wireless links), wireline links (e.g., optic-fiber lines, coaxial cables, and/or twisted-pair lines), or a combination thereof.
The first group of communication links 1374 and the second group of communication links 1372 can permit or otherwise facilitate the exchange of information (e.g., data, metadata, and/or signaling) between at least one of the computing device(s) 1370 and the computing device 1310. To that end, one or more links of the first group of communication links 1374, one or more links of the second group of communication links 1374, and at least one of the network(s) 1380 can form a communication pathway between the communication device 1310 and at least one of the computing device(s) 1370.
In one or more embodiments, one or more of the disclosed methods can be practiced in distributed computing environments, such as grid-based environments, where tasks can be performed by remote processing devices (computing device(s) 1370) that are functionally coupled (e.g., communicatively linked or otherwise coupled) through at least one of network(s) 1310. In a distributed computing environment, in one aspect, one or more software components (such as program modules) can be located within both a local computing device (e.g., computing device 1310) and at least one remote computing device.
Various embodiments of the disclosure may take the form of an entirely or partially hardware embodiment, an entirely or partially software embodiment, or a combination of software and hardware. Further, as described herein, various embodiments of the disclosure (e.g., systems and methods) may take the form of a computer program product including a computer-readable non-transitory storage medium having computer-accessible instructions (e.g., computer-readable and/or computer-executable instructions) such as computer software, encoded or otherwise embodied in such storage medium. Those instructions can be read or otherwise accessed and executed by one or more processors to perform or permit the performance of the operations described herein. The instructions can be provided in any suitable form, such as source code, compiled code, interpreted code, executable code, static code, dynamic code, assembler code, combinations of the foregoing, and the like. Any suitable computer-readable non-transitory storage medium may be utilized to form the computer program product. For instance, the computer-readable medium may include any tangible non-transitory medium for storing information in a form readable or otherwise accessible by one or more computers or processor(s) functionally coupled thereto. Non-transitory storage media can be embodied in or can include ROM; RAM; magnetic disk storage media; optical storage media; flash memory, etc.
At least some of the embodiments of the operational environments and techniques are described herein with reference to block diagrams and flowchart illustrations of methods, systems, apparatuses, and computer program products. It can be understood that each block of the block diagrams and flowchart illustrations, and combinations of blocks in the block diagrams and flowchart illustrations, respectively, can be implemented by computer-accessible instructions. In certain implementations, the computer-accessible instructions may be loaded or otherwise incorporated into a general purpose computer, special purpose computer, or other programmable information processing apparatus to produce a particular machine, such that the operations or functions specified in the flowchart block or blocks can be implemented in response to execution at the computer or processing apparatus.
Unless otherwise expressly stated, it is in no way intended that any protocol, procedure, process, or technique put forth herein be construed as requiring that its acts or steps be performed in a specific order. Accordingly, where a process or a method claim does not actually recite an order to be followed by its acts or steps or it is not otherwise specifically recited in the claims or descriptions of the subject disclosure that the steps are to be limited to a specific order, it is in no way intended that an order be inferred, in any respect. This holds for any possible non-express basis for interpretation, including: matters of logic with respect to the arrangement of steps or operational flow; plain meaning derived from grammatical organization or punctuation; the number or type of embodiments described in the specification or annexed drawings, or the like.
As used in this application, the terms “environment,” “system,” “module,” “component,” “architecture,” “interface,” and the like refer to a computer-related entity or an entity related to an operational apparatus with one or more defined functionalities. The terms “environment,” “system,” “module,” “component,” “architecture,” “interface,” and “unit,” can be utilized interchangeably and can be generically referred to functional elements. Such entities may be either hardware, a combination of hardware and software, software, or software in execution. As an example, a module can be embodied in a process running on a processor, a processor, an object, an executable portion of software, a thread of execution, a program, and/or a computing device. As another example, both a software application executing on a computing device and the computing device can embody a module. As yet another example, one or more modules may reside within a process and/or thread of execution. A module may be localized on one computing device or distributed between two or more computing devices. As is disclosed herein, a module can execute from various computer-readable non-transitory storage media having various data structures stored thereon. Modules can communicate via local and/or remote processes in accordance, for example, with a signal (either analogic or digital) having one or more data packets (e.g., data from one component interacting with another component in a local system, distributed system, and/or across a network such as a wide area network with other systems via the signal).
As yet another example, a module can be embodied in or can include an apparatus with a defined functionality provided by mechanical parts operated by electric or electronic circuitry that is controlled by a software application or firmware application executed by a processor. Such a processor can be internal or external to the apparatus and can execute at least part of the software or firmware application. Still in another example, a module can be embodied in or can include an apparatus that provides defined functionality through electronic components without mechanical parts. The electronic components can include a processor to execute software or firmware that permits or otherwise facilitates, at least in part, the functionality of the electronic components.
In some embodiments, modules can communicate via local and/or remote processes in accordance, for example, with a signal (either analog or digital) having one or more data packets (e.g., data from one component interacting with another component in a local system, distributed system, and/or across a network such as a wide area network with other systems via the signal). In addition, or in other embodiments, modules can communicate or otherwise be coupled via thermal, mechanical, electrical, and/or electromechanical coupling mechanisms (such as conduits, connectors, combinations thereof, or the like). An interface can include input/output (I/O) components as well as associated processors, applications, and/or other programming components.
As is utilized in this disclosure, the term “processor” can refer to any type of processing circuitry or device. A processor can be implemented as a combination of processing circuitry or computing processing units (such as CPUs, GPUs, or a combination of both). Therefore, for the sake of illustration, a processor can refer to a single-core processor; a single processor with software multithread execution capability; a multi-core processor; a multi-core processor with software multithread execution capability; a multi-core processor with hardware multithread technology; a parallel processing (or computing) platform; and parallel computing platforms with distributed shared memory.
Additionally, or as another example, a processor can refer to an integrated circuit (IC), an application-specific integrated circuit (ASIC), a digital signal processor (DSP), a field programmable gate array (FPGA), a programmable logic controller (PLC), a complex programmable logic device (CPLD), a discrete gate or transistor logic, discrete hardware components, or any combination thereof designed or otherwise configured (e.g., manufactured) to perform the functions described herein.
In some embodiments, processors can utilize nanoscale architectures. in order to optimize space usage or enhance the performance of systems, devices, or other electronic equipment in accordance with this disclosure. For instance, a processor can include molecular transistors and/or quantum-dot based transistors, switches, and gates,
Further, in the present specification and annexed drawings, terms such as “store,” “storage,” “data store,” “data storage,” “memory,” “repository,” and substantially any other information storage component relevant to the operation and functionality of a component of the disclosure, refer to memory components, entities embodied in one or several memory devices, or components forming a memory device. It is noted that the memory components or memory devices described herein embody or include non-transitory computer storage media that can be readable or otherwise accessible by a computing device. Such media can be implemented in any methods or technology for storage of information, such as machine-accessible instructions (e.g., computer-readable instructions), information structures, program modules, or other information objects.
Memory components or memory devices disclosed herein can be embodied in either volatile memory or non-volatile memory or can include both volatile and non-volatile memory. In addition, the memory components or memory devices can be removable or non-removable, and/or internal or external to a computing device or component. Examples of various types of non-transitory storage media can include hard-disc drives, zip drives, CD-ROMs, digital versatile disks (DVDs) or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, flash memory cards or other types of memory cards, cartridges, or any other non-transitory medium suitable to retain the desired information and which can be accessed by a computing device.
As an illustration, non-volatile memory can include read only memory (ROM), programmable ROM (PROM), electrically programmable ROM (EPROM), electrically erasable programmable ROM (EEPROM), or flash memory. Volatile memory can include random access memory (RANI), which acts as external cache memory. By way of illustration and not limitation, RANI is available in many forms such as synchronous RANI (SRAM), dynamic RANI (DRAM), synchronous DRAM (SDRAM), double data rate SDRAM (DDR SDRAM), enhanced SDRAM (ESDRAM), Synchlink DRAM (SLDRAM), and direct Rambus RAM (DRRAM). The disclosed memory devices or memories of the operational or computational environments described herein are intended to include one or more of these and/or any other suitable types of memory.
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 implementations could include, while other implementations do not include, certain features, elements, and/or operations. Thus, such conditional language generally is not intended to imply that features, elements, and/or operations are in any way required for one or more implementations or that one or more implementations necessarily include logic for deciding, with or without user input or prompting, whether these features, elements, and/or operations are included or are to be performed in any particular implementation.
The flowchart and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of examples of systems, methods, and computer program products according to various embodiments of the present disclosure. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of instructions, which includes one or more machine- or computer-executable instructions for implementing the specified operations. It is noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or operations or carry out combinations of special purpose hardware and computer instructions.
Computer readable program instructions described herein can be downloaded to respective computing/processing devices from a computer readable storage medium or to an external computer or external storage device via a network, for example, the Internet, a local area network, a wide area network and/or a wireless network. The network can include copper transmission cables, optical transmission fibers, wireless transmission, routers, firewalls, switches, gateway computers and/or edge servers. A network adapter card or network interface in each computing/processing device receives computer readable program instructions from the network and forwards the computer readable program instructions for storage in a computer-readable non-transitory storage medium within the respective computing/processing device.
What has been described herein in the present specification and annexed drawings includes examples of systems, devices, techniques, and computer program products that, individually or in combination, permit generating synthetic time series using a generative adversarial network. It is, of course, not possible to describe every conceivable combination of components and/or methods for purposes of describing the various elements of the disclosure, but it can be recognized that many further combinations and permutations of the disclosed elements are possible. Accordingly, it may be apparent that various modifications can be made to the disclosure without departing from the scope or spirit thereof. In addition, or as an alternative, other embodiments of the disclosure may be apparent from consideration of the specification and annexed drawings, and practice of the disclosure as presented herein. It is intended that the examples put forth in the specification and annexed drawings be considered, in all respects, as illustrative and not limiting. Although specific terms are employed herein, they are used in a generic and descriptive sense only and not for purposes of limitation.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/US2018/049216 | 8/31/2018 | WO | 00 |