The present application relates generally to computers and computer applications, and more particularly to neural networks and neuro-symbolic networks.
Artificial intelligence methodologies include principled, deductive inference via any of various systems of formal logic, and data-driven, gradient optimized neural networks. Both paradigms bear a number of strengths and weaknesses. For example, formal logic is interpretable, verifiable, and broadly generalizable, though it is computationally intensive, requires extensive domain expert input, and can be derailed by inconsistencies. Neural networks, on the other hand, perform well even for unprocessed and/or noisy data, require little human configuration, and can run efficiently in parallel. Neural networks, however, may need large training data sets, may be vulnerable to adversarial attacks, and can have uninterpretable black-box characteristic.
A method of learning of weighted real-valued logic implemented in a neural network of logical neurons, in an aspect, can include receiving maximum expressivity representing a ratio between maximum and minimum input weights to a neuron of a neural network implementing a weighted real-valued logic gate. The method can also include receiving operator arity associated with the neuron. The method can further include defining logical constraints associated with the weighted real-valued logic gate in terms of weights associated with inputs to the neuron, a threshold-of-truth, and a neuron threshold for activation. The method can also include determining the threshold-of-truth as a parameter used in an activation function of the neuron, based on solving an activation optimization formulated based on the logical constraints. The activation optimization maximizes a product of, expressivity representing a distribution width of input weights to the neuron and gradient quality for the neuron, given the operator arity and the maximum expressivity. The method can also include training the neural network of logical neurons using the activation function at the neuron, the activation function using the determined threshold-of-truth.
A system, in one aspect, can include a hardware processor. A memory device can be coupled with the hardware processor. The hardware processor can be configured to receive maximum expressivity representing a ratio between maximum and minimum input weights to a neuron of a neural network implementing a weighted real-valued logic gate. The hardware processor can also be configured to receive operator arity associated with the neuron. The hardware processor can also be configured to define logical constraints associated with the weighted real-valued logic gate in terms of weights associated with inputs to the neuron, a threshold-of-truth, and a neuron threshold for activation. The hardware processor can also be configured to determine the threshold-of-truth as a parameter used in an activation function of the neuron, based on solving an activation optimization. The activation optimization can be formulated based on the logical constraints. The activation optimization maximizes a product of, expressivity representing a distribution width of input weights to the neuron and gradient quality for the neuron, given the operator arity and the maximum expressivity. The hardware processor can also be configured to train the neural network of logical neurons using the activation function at the neuron, the activation function using the determined threshold-of-truth.
A computer readable storage medium storing a program of instructions executable by a machine to perform one or more methods described herein also may be provided.
Further features as well as the structure and operation of various embodiments are described in detail below with reference to the accompanying drawings. In the drawings, like reference numbers indicate identical or functionally similar elements.
Systems, methods and techniques are presented, which can determine various parameters for optimizing machine learning models, e.g., neural networks. A method, for example, may determine the threshold-of-truth (alpha), activation function and logical constraints (e.g., convex optimization linear program) of weighted real-valued logic operators such as logical neurons (e.g., weighted offset Łukasiewicz real-valued strong conjunction and/or disjunction operators) to optimize the functional gradients of the activation function for a given maximum expressivity (e.g., defined by the ratio between the maximum and minimum input weights) and operator size or arity (number of operands). In an aspect, various parameters for machine learning determined according to embodiments of the systems, methods and techniques can address a vanishing gradient problem in machine learning, for example, having too small of gradients which renders machine training difficult.
An artificial neural network (ANN) or neural network (NN) is a machine learning model, which can be trained to predict or classify an input data. An artificial neural network can include a succession of layers of neurons, which are interconnected so that output signals of neurons in one layer are weighted and transmitted to neurons in the next layer. A neuron Ni in a given layer may be connected to one or more neurons Nj in the next layer, and different weights wij can be associated with each neuron-neuron connection Ni-Nj for weighting signals transmitted from Ni to Nj. A neuron Nj generates output signals dependent on its accumulated inputs, and weighted signals can be propagated over successive layers of the network from an input to an output neuron layer. An artificial neural network machine learning model can undergo a training phase in which the sets of weights associated with respective neuron layers are determined. The network is exposed to a set of training data, in an iterative training scheme in which the weights are repeatedly updated as the network “learns” from the training data. The resulting trained model, with weights defined via the training operation, can be applied to perform a task based on new data.
An example of a neural network is a recurrent neural network, which can handle time series data or sequence based-data such as sentences in a language. A recurrent neural network model can have a series of neural network cells, which take as input a data in the series and also activation information from the previous neural network in the previous time step.
Fuzzy logic is a logical system in which the Boolean operators of classical logic have been replaced with functions operating on real numbers in the range [0; 1]. Beyond a means of evaluating the truth values of various formulae based on their subformulae, fuzzy logic aims to provide a calculus whereby the truth values of propositions (or predicates) can be inferred from one another in conjunction with a knowledge base (theory) of axioms, themselves assigned fuzzy truth values.
In weighted fuzzy logic, logical formulae and/or their components bear real-valued weights representing importance, influence, or some related concept. Such a system of logic allows more flexible expressions of the relationships between propositions (or predicates if extended to first-order logic). Weighted fuzzy logic is suited for automated learning because it grants a continuous means of adjusting each operand's effect in a given formula.
For example, Łukasiewicz logic is a real-valued logic or many-valued logic in which sentences may be assigned a truth value of not only zero or one but also any real number in between (e.g. 0.3). The propositional connectives of Łukasiewicz logic include implication→, negation ¬, equivalence ↔, weak conjunction ∧, strong conjunction ⊗, weak disjunction ∨, strong disjunction ⊕, and propositional constants 0 and 1.
A neuro-symbolic representation is a weighted, real-valued logic in neural network form that can be constrained to behave equivalently to classical logic (or fuzzy logic). In embodiments, the system and method can determine various parameters for a neuro-symbolic representation, which includes neurons evaluating classical logic functions, for example, similar to activation functions.
For instance, a neural network in an embodiment includes logical neurons. A logical neuron can emulate a logical gate such as AND, OR, IMPLIES, NOT, and/or others. A neural network of logical neurons can be trained to implement a logical rule and perform logical reasoning. Logical neurons are similar to any sigmoidal neuron used in neural networks, but can differ in the following properties. Weights of logical neurons are constrained such that their outputs reflect the behavior of operations occurring in classical logic, e.g., AND, OR, and IMPLIES. Their inputs and outputs are understood to be bounds on truth values. Truth values range from 0 to 1, though may be interpreted classically if they are bounded above some (e.g., defined) threshold or below 1, e.g., above a threshold α or below 1−α. They can be evaluated as normal or used to perform modus ponens, whereby bounds for each input are computed based on known bounds for the output and the other inputs. Modus ponens refers to the rule of logic stating that if a conditional statement (“if p then q”) is accepted, and the antecedent (p) holds, then the consequent (q) may be inferred.
Given the logistic function S(x)=(1+exp(−x))−1 and a chosen threshold of truth 0.5<α<1, it is useful to define a scaled and offset α-preserving sigmoid
As per its definition, this function has the property that Sα(α)=α and Sα(1−α)=1−α. For logical neurons indexed j∈N, normal computation is then
a
j
=S
α(Σi∈I
for truth value inputs xi, input weights wi,j, activation threshold θj, and activation output αj. The inputs to logical neurons can be the outputs of other logical neurons or the outputs of specialized neurons pertaining to propositions. As a result of modeling operations in logical formulae, the size of input set Ij can be very small, e.g., just 2 for binary operations, though associative operators can have more inputs. In another aspect, one can consider Ij to be larger but with most weights wi exactly equal to 0.
An activation function at each neuron may compute an output of that neuron or node, and can be chosen to represent a particular logical operation or a family of operations. Each node in the network may compute as output an upper bound and lower bound values for its truth values. These upper bound and lower bound truth values are continuous variables at each node and passed around the network. These bounded truth value variables are computed at a node at prediction time or inference time, and they are computed based on the inputs and computed with respective to importance weights which have been learned.
Constraints on logical neurons (e.g., logical constraints) can be derived from the truth tables of the operations they intend to model and from established ranges for “true” and “false” values. In an aspect, a continuous truth values is considered true if its lower bound is at least a and false if its upper bound is at most 1−α. Using the α-preserving sigmoid, it can be enough to constrain the results of its linear argument to lie above or below the appropriate such threshold.
As an example, the truth table for, e.g., binary AND suggests a set of constraints given:
where θ is a threshold, w represent weights.
For example, a false logic value (0) is represented as (1−α) and true logic value (1) is represented as α in deriving the constraints.
More generally, n-ary conjunctions (of positive inputs) have constraints of the form
∀k∈I,wk≥0
αΣi∈Iwi−θ≥α (3)
∀k∈I,Σi∈Iwi−wkα−θ≤1−α (4)
while n-ary disjunctions have constraints of the form
∀k∈I,wk≥0
∀k∈I,wkα−θ≥α (5)
(1−α)Σi∈Iwi−θ≤1−α (6)
For example, (3) requires conjunctions to return true if all of their inputs are true, while (4) requires them to return false if any of their inputs are false, even if their other inputs are all 1, i.e., maximally true the converse if true of disjunctions. Given negation defined ¬p=1−p, the classical identity p→q=¬p∨q permits implications to use the same constraints as disjunctions. The above two sets of constraints are equivalent under the DeMorgan laws, e.g., p¬q=¬(¬p∧¬q).
As a result of these constraints, normal evaluation of logical neurons is guaranteed to yield results within the established ranges for true and false if all of their inputs are within these ranges as well.
For activation linear inputs of the form t−Σi∈Iwi (1−xi) for conjunctions and 1−t+Σi∈Iwixi for disjunctions, constraints are equivalent to the above with θ=Σi∈Iwi−t and θ=t−1, respectively. This then suggests constraints of the form
In an aspect, reasoning in terms of bounds on truth values mitigates a number of challenges inherent in implementing logical inference in a neural network. Bounds offer an elegant and intuitive mechanism to express the four states a truth value can occupy during inference: unknown, known true, known false, and known contradiction. Bounds provide a mechanism whereby modus ponens can return a nonresult. Reasoning in terms of bounds facilitates the ability to aggregate multiple proofs for the same proposition.
It can be desirable for an input's weight to be able to drop to exactly 0, thereby effectively removing it from I. To permit this, a slack variable (s) can be introduce for each weight, allowing its respective constraints in (4) or (5) to be violated as the weight drops to 0:
∀k∈I,sk≥0
∀k∈I,Σi∈Iwi−wkα−sk−θ≤1−α (4*)
∀k∈I,wkα+sk−θ≥α (5*)
These remain consistent with the original constraints if either sk=0 or wk=0. An optimization can include choosing such parameterizations by updating the training loss function to include a penalty term scaling with skwk. The coefficient on this penalty term controls how classical learned operations are, with exact classical behavior restored if optimization reduces the penalty term to 0.
ƒ(t−Σw(1−x))
The logical neuron receives one or more input operands x0, x1, . . . , xi, . . . , xn with each operand having a respective assigned or computed weight w0, w1, . . . , wi, . . . , wn representing an importance. The input values are combined according to the defined formulation, t−Σw(1−x), and input to the neuron activation function ƒ. “t” represents the maximum input expected for the neuron activation, which corresponds to where the output of the logical conjunction is fully true.
By way of example, a conjunction (&, also AND) neuron can be defined as:
&(x)=ƒ(t−w·(1−x).
Constraints or logical constraints to the conjunction neuron can be defined as follows:
∀i:t−(wiα+si)≤1−α
t−Σw(1−α)≥α
Where, ∀i: wi≥0, si≥0
In an embodiment, the system determines parameter values, including threshold of truth and activation threshold, for the parameterized activation ƒ that maximizes the product of the expressivity and gradient quality for the expected input distribution to the activation function as calculated in the argument to the activation function in the logical neuron. In an embodiment, in constrained neurons: 1. ƒ is odd, monotonically increasing, range [0,1], and alpha (α) preserving; 2. Define degree of truth for thresholding: e.g., 0.5<α≤1; 3. Slacks si allow for input removal; 4. For example, one false input to a logical conjunction (AND) neuron should make its output false.
A neuro-symbolic representation can have a neural network formed of a plurality of logical neurons forming a logical formula.
As shown in
As shown in
For the use-case example, for sub-graph 218 “cat” node can be weighted twice as important as “dog” and thus is a modified version of the disjunction “OR” connective that skews results in the sense that “cat” now has more influence than “dog” does in the formula.
Each of the syntax tree graphs 204, 207 for respective formula are constructed based on an initial list of input propositions 202 having a defined truth value (e.g., true or false) including: “whiskers” 202A, “tail” 202B, “laser pointer” 202C,“chases” 202D, “cat” 202E1, 202E2, “dog” 202F, and “pet” 202D existing in the formulae. Alternately, these inputs could be predicates, e.g., statements whose truth value depends upon more than one variable(s). The logical formulae 205, 208 are applied that result in an evaluation of a respective inference or implication (e.g., “Whiskers∧Tail∧(Laser pointer→Chases)), →Cat”) and evaluation of an inference or implication (e.g., “Cat∨Dog)→Pet”). In
An example recurrent (bi-directional) backward inference (backwards passes) is shown in
In embodiments, information is back-propagated along the following backwards paths to update inverse function computations in tree 204: i.e., the path as shown by arrows 242, 242A where the truth value (i.e., upper bounds and lower bounds) of the whiskers predicate 202A is updated by the inverse activation function computation at the conjunction neuron 210A; the path as shown by arrows 242, 242B where the truth value (upper bounds and lower bounds) of the tail predicate 202B is updated by the inverse activation function computation at the conjunction neuron 210A; the path as shown by arrows 242, 242C, 242D where the truth value (upper bounds and lower bounds) of the laser pointer predicate 202C is updated by the inverse activation function computations at the conjunction neuron 210A and implication neuron 210B; the path as shown by arrows 242, 242C, 242E where the truth value (upper bounds and lower bounds) of the chases predicate 202D is updated by inverse activation function computation at the conjunction neuron 210A and at the implication neuron 210B; and the path as shown by arrow 243 where the truth value (upper bounds and lower bounds) for the cat predicate 202E1 is updated by inverse activation function computation at the implication neuron 215. Similarly, the following backwards paths are traversed to perform inverse function computations in syntax tree 207: i.e., the path as shown by arrows 272, 272A where the truth value (upper bounds and lower bounds) for the cat predicate 202E2 is updated by the inverse activation function computation at the disjunction neuron 210C; the path as shown by arrows 272, 272B where the truth value (upper bounds and lower bounds) of the dog predicate 202F is updated by the inverse activation function computation at the disjunction neuron 210C; and the path as shown by arrow 273 where the truth value (upper bounds and lower bounds) for the pet predicate 202G is updated by inverse activation function computation at the implication neuron 225.
In one aspect, fuzzy logic is employed that provides probabilities of truth values that range between zero and one, i.e., values in between 0 and 1 are ambiguous mixtures between true and false. In an embodiment, alpha a is defined as a threshold of truth ranging between, e.g., 0.5<α≤1. Thus, any evaluated truth value is constrained such that values above α are considered “true” and any truth value less than a quantity 1−α is considered “false”.
An activation function 211 is the particular function at each neuron 210 to compute an output of that neuron, and is chosen to represent a particular logical operation or a family of activation functions are chosen that represent logical operations that are consistent with a particular logic scheme, e.g., Łukasiewicz logic. For example, as shown in sub-formula 218 the activation function is a disjunction function that is evaluated as the addition (sum) of the inputs. In the “unweighted” case example depicted in
In an embodiment, for real-valued logical connectives, example activation functions compute truth value according to constraints as follows:
For a Conjunction (AND):
p⊗q=max(0,p+q−1)
where p and q are operands, the constraint is the sum of the two operand value inputs minus 1 clamped below by 0.
For Disjunction (OR):
p⊕q=1−((1−p)⊗(1−q))=min(1,p+q)
i.e., the sum of the two operand input values clamped above by 1.
For Implication (→)
p→q=(1−p)⊗q=min(1,1−p+q)
i.e., is similar to disjunction however, one of the inputs is negated (1−p). As an example, as shown at node 210A, the activation function is a conjunction function. In the “unweighted” case example depicted in
Other activation functions according to other logic schemes can be employed in embodiments. Moreover, different logistic functions can be used as activation functions in different parts of the NN. For example, a “weighted” Lukasiewicz logic scheme for logical connectives is employed, where activation functions compute truth values as follows: For the activation function of neurons corresponding to AND, a weighted Lukasiewicz t-norm is defined as:
p
(w
)⊗βq(w
Then, for disjunction case (OR) the following associated weighted t-conorm can be used:
p
(w
)⊕βq(w
For an Implication (→):
p
(w
)→βq(w
In each of the above constraints, β is a bias term establishing an operation, weights w express importance, with wp a weight for input operand p and wq a weight of input operand q. Bias term β can be a value of 1, although it could be another value. Inside the clamps is an expression or formula of a hyperplane, i.e., a dot product between the weights (inputs) vector plus an offset.
Systems and methods in embodiments may determine various parameters used in training such above described neural network. A method, for example, in an embodiment may implement and learn logic with special artificial neurons, for instance, which can address the problem of uncovering logic from observations, correcting logical programs, and integrating logical reasoning into neural networks and differentiable learning systems. The method may approximate neuron activation function to provide non-zero gradients. The method may also quantify the relative gradient magnitude. The method may also define the neuron input weights expressivity. The method may also optimize the tradeoff between gradient quality and expressivity. The method may also define an optimal activation function and set of logical constraints for the logical neurons.
Gradient quality relates to availability of non-zero and/or relatively non-small gradients in the operating range of the neuron's activation function, where high gradient quality ensures that there is non-zero and relatively non-small change in truth-value outputs for a change in the neuron parameters. Gradient quality relates to ensuring the ability to calculate error gradients under all conditions, for example, so that learning can happen through gradient descent. In an embodiment, gradient quality is a relative scalar measure and can be expressed in terms of a ratio-averaged flanks gradient, an average gradient involving flank gradients that are ratio-averaged. In optimizing an activation function (the neuron's activation function), the gradient quality measure can be used relatively, e.g., choosing an optimization direction where the gradient quality at a new optimum is higher than at a previous optimum. An activation function with a higher ratio-averaged flanks gradient is considered to have higher quality, than one with a less ratio-averaged flanks gradient. Expressivity refers to the ratio of the smallest to largest input weight of a neuron, and relates to the distribution width of input weights to logical neurons.
Threshold-of-truth refers to the limit over which real-valued truth values are considered to be true, and can be used for external interpretation in terms of classical true/false truth values. In an embodiment, the threshold-of-truth can be a learnable parameter of the activation function. Notation for representing threshold-of truth can be “a”. A continuous truth value is considered true if its lower bound is at least a and false if its upper bound is at most 1−α.
In an operator with a user-specified arity and user-specified maximum expressivity, a method in an embodiment calculates alpha (α) that maximizes the product of expressivity and gradient quality at the user-specified maximum expressivity. In an aspect, alpha is the threshold-of-truth that can be used for external interpretation of truth values in a classical true/false sense, and by setting it to less than 1, it allows for non-zero gradients. For instance, non-zero gradients facilitate machine training, for example, in back-propagation and can lessen or alleviate the problem of vanishing gradients.
The following notations are also used in the description herein.
Arity refers to the number of input connections to the neuron, where a weight parameter is associated and multiplied with every input.
Maximum expressivity refers to the largest difference in input importance that can be expressed via the weighting of the neuron inputs (inputs to a neuron), and provides a guarantee for the input weight differences that can be supported by the logical neuron.
“t_max” refers to the upper bound of the maximum input expected for the neuron activation, which corresponds with the upper bound of the threshold in the logical neuron formulation. It is the maximum that the threshold of the logical neuron formulation can be set under the given constraints.
“t” refers to the maximum input expected for the neuron activation, which corresponds to where the output of the logical conjunction is fully true.
“t-sum(w)” (t minus summation of w's of a neuron, where w represents a weight associated with an input) refers to the minimum expected input to the logical neuron's activation function, corresponding to a logical conjunction with an output of fully false.
The method herein in one embodiment calculates t_max that is the upper bound of the neuron threshold, and sets the upper bound of t that is the neuron threshold in the constrained linear program (that calculates updated neuron parameters) to t_max indefinitely. T_max can be calculated based on logical constraints derived from a truth table of an operator (e.g., AND operator). When the system has a threshold of truth setting alpha <1 (which can be normally the case, as this provides non-zero gradients in the entire operating range of the neuron) this will also constrain the size and sum of the neuron input weights through the given constraint of t-sum(w)(1−alpha)>=alpha. This minimizes the allowable neuron input weight parameter region while providing for a desired level of expressivity or variation in the neuron input weights, and a minimal convex region can help reduce large abrupt parameter steps during the optimization phase.
In an embodiment, arity, maximum expressivity, alpha, t_max are determined during the initialization phase of the logical neuron and kept fixed afterward during all future neuron weight parameter updates (e.g., during training). In an embodiment, the learning method may also look at changing the threshold of truth alpha associated with the logical neuron, based on the current weight expressivity that supports up to a specific weight difference ratio between weights, to optimize the gradient quality at the current expressivity. This changing of alpha can be performed when current expressivity has changed, that is when the neuron input weight ratio's have changed e.g., the ratio of the maximum to the minimum weights.
In an embodiment, every operator can keep its own 3-piece leaky rectified linear unit (ReLU) activation function, which is updated to saturate at t and t-sum(w) after every parameter update. According to the defined activation function objective, a 3-piece leaky ReLU can be optimal. Briefly, ReLU is a type of activation function, which can be used in neural networks. In leaky ReLU, when x<0, a leaky ReLU can have a small negative slope (e.g., 0.01, or so) instead of the function being zero.
Observations can be made based on the relationship between, arity, expressivity and alpha. For example, an increase in arity may decrease gradient quality. Based on this observation, in an embodiment, a method herein may set a maximum allowable arity and leverage composition and associativity to build larger arity gates from small arity gates.
In an embodiment, an optimum for alpha is determined to maximize the tradeoff between expressivity and quality of learning (gradients). In addition to expressivity, which describes the ratio between the maximum and minimum weights, slack variables can be introduced. The slacks can still allow for inputs to be removed entirely (e.g., by setting or having the weight (w) to zero (e.g., w=0)) without requiring higher expressivity. For example, a constraint slack variable can be introduced for each weight during the learning phase so that the constrained linear program is allowed (through the slack variables) to set weight values that would otherwise have been infeasible as it would have violated the logical constraint. The effective arity may be recalculated, together with alpha and t_max, when inputs are dropped.
A method herein determines the threshold-of-truth (alpha), activation function and logical constraints (e.g., convex optimization linear program) of weighted real-valued logic operators such as logical neurons (e.g., weighted offset Łukasiewicz real-valued strong conjunction or disjunction operators) to optimize the functional gradients of the activation function for a given maximum expressivity (e.g., defined by the ratio between the maximum and minimum input weights) and operator size or arity. Real-valued logic refers to a many-valued logic in which truth values comprise a continuous range.
The method in an embodiment can introduce a relaxation to the logical constraints to enable improved expressivity and machine learning by defining a threshold-of-truth (alpha) that is the uncertainty above which truth-values behave like classical logic true values, and a threshold-of-falsity (1−alpha) below which values behave classically false.
The method in an embodiment can calculate a measure of gradient quality for the activation function of a logical neuron by obtaining the ratio-average gradients only for the parts of its operating region respectively above and below the threshold-of-truth and threshold-of-falsity, given the threshold-of-truth. In an embodiment, gradient quality is a relative scalar measure, which can be measured in terms of the ratio-averaged flanks gradient.
The method in an embodiment can incorporate the expressivity or capacity of the logical operator into its logical constraints to establish a relationship between expressivity and the threshold-of-truth, by modeling the weight distribution such that the sum of weights can be determined given only the minimum weight and expressivity.
where n represents the number of input weights or arity.
In an embodiment, in addition to symmetric weight distributions like uniform and normal, the method can also admit asymmetric weight distributions and determine the relationship between the allowable expressivity and threshold-of-truth. An embodiment may model input weights according to a Poisson distribution (also inversely) describing the amount of events per interval. For example, in an example use case involving electronic mail (emails), an embodiment of a method can model input weights according to a Poisson distribution (also inversely) describing the amount of events per interval, e.g., according to the number of emails received or responses made per day for a given input email (or email inbox) in a logical filter that filters unwanted or inappropriate email. When a logical filter of an email provider analyzes incoming email activity/counts for each of the email users/inboxes, then a logic rule takes the receipt of a suspected email (Boolean condition) at each of these inboxes as input to determine a real-valued logic output that is true when the suspected email is deemed to be an unwanted email or false otherwise. A logical filter can provide a classification or labeling of emails based on internal logical processing. For example, an email provider hosts email storage, sending, receipt and access services for its registered users. A logical filter is automatically applied to all incoming emails to a user's inbox in order to provide a label or classification, such as whether an email comes from a reputable source. A logical filter can have internal processing based on one or more logical rules that take as input truth values associated with, e.g., external conditions about an email or user, such as whether an email sender address domain is the same as the sending email server domain. The disclosed method can produce a real-unit interval [0, 1] truth-value from the logical filter, such as to indicate how suspected an email is, based on the input propositions and features of the email. The input weight to the logical operator taking propositions of whether an input email has received suspected email can thus incorporate relevant information that can increase or decrease the influence of the input. For example, if the network of neurons with logical operator activations receives many incoming emails, then suspected email is expected, and that input is down-weighted, i.e., the weight for that input (or neuron) is decreased. For example, if the logical filter observes that many inboxes that do not typically receive suspected emails do all receive the same email, then this is a stronger indication that this email is suspect. Whereas, if an inbox that typically receives many emails also receives the suspected email, then it could weigh less as a vote for suspecting the email, than from another inbox that receives far fewer emails.
In an embodiment, a lower bound on the minimum weight is determined in terms of expressivity, operator arity and threshold-of-truth. Where only uniform expressivity is desired, the calculation can be simplified by system-wide setting of expressivity to 1.
The method in an embodiment can construct and continually update an activation function for a given threshold-of-truth to optimize the gradients of the activation function over the logical operating range, e.g., by forming a piecewise linear function that is false at the operating range minimum, at threshold-of-falsity for a threshold-of-falsity input, at threshold-of-truth for a threshold-of-truth input, and true at the operating range maximum. In an embodiment, operating range of false is [0, 1-alpha]. In an embodiment, operating range of true is [alpha, 1].
The method in an embodiment can set the threshold-of-truth to the same value indefinitely that maximizes the product of expressivity and the gradient quality at maximum expressivity. The threshold-of-truth value can be updated based on the current expressivity. For example, expressivity can change as weights are learned and changed. Based on a changed expressivity, the threshold-of-truth value can be recomputed or updated.
In an embodiment, method can include determining and updating the threshold-of-truth. The method may also include providing a user interface that calculates, updates and visualizes various aspects and properties of real-valued logic operators based on a set of user value selections. Relevant values of expressivity and arity can be decided based on the various aspects and properties of real-valued logic. For example, the method may visualize the logical decision surface and operating region and analyze the effect of expressivity and arity on it, and also determine viable parameter regions ensuring lower bounds on expressivity.
The method in an embodiment can introduce slacks in the logical constraints to allow for inputs to receive zero weight without requiring a corresponding change in the defined expressivity value to allow inputs to be removed completely.
The method in an embodiment can set the maximum logical offset (e.g., for weighted offset Łukasiewicz real-valued strong conjunction or disjunction operators) and the corresponding offset upper bound in the logical constraints to the same value indefinitely given the specified formula taking threshold-of-truth, arity and expressivity as inputs.
In an embodiment, the method specifies the threshold-of-truth as the learnable parameter of the activation function. In an embodiment, an activation function optimization specifies particulars to ensure logical functionality.
Explicitly reasoning in terms of bounds on truth values mitigates a number of challenges inherent in implementing logical inference in a neural network. Bounds offer an elegant and intuitive mechanism to express the four states a truth value can occupy during inference: unknown, known true, known false, and known contradiction. Bounds provide a mechanism whereby modus ponens can return a nonresult. Reasoning in terms of bounds facilitates the ability to aggregate multiple proofs for the same proposition.
The following illustrates determining the threshold-of-truth (alpha), activation function and logical constraints (e.g. convex optimization linear program) of weighted real-valued logic operator or logical neuron, which implements an AND operation or gate. The systems and methods can also apply to other logic gates or operations.
In an embodiment, a logical neuron corresponding to a logical conjunction or AND operation on a vector x of logical truth-values in range [0, 1] can be defined in the form of Łukasiewicz fuzzy t-norm (triangle-norm) being the argument to the neuron activation function ƒ as follows:
ƒ(t−Σw(1−x))
The following illustrates defining expressivity and threshold-of-truth a in an embodiment. The following notations are used in the formulations.
t represents the neuron threshold or bias, which corresponds to the maximum input to the neuron activation function.
w represents a vector of learnable weight parameters associated with each of the inputs to the logical neuron.
α represents the threshold of truth for the neuron, above which truth-values (between the range of 0 and 1) may be interpreted as classically true.
n represents the arity or number of inputs to the logical neuron.
λ represents the expressivity or the ratio of the maximum input weight to the minimum input weight.
t_min represents a lower bound on the neuron threshold, which corresponds to the least the neuron threshold can be set to while still satisfying the neuron logical constraints.
w_min represents the minimum input weight among the set of input weights to the logical neuron.
s represents a vector of slack variables, one associated with each of the input weight parameters to the logical neuron. These slack variables are used to determine constraint satisfaction and to calculate loss terms, but are not otherwise used in, e.g., the inference phase of the logical neuron.
s_i represents a specific slack variable associated with neuron input indexed by integer i.
x_min represents the minimum point in the operating range of the logical neuron, which corresponds to the minimum input expected to the activation function of the logical neuron.
t_max represents the upper bound on the neuron threshold, which corresponds to the greatest the neuron threshold can be set to while satisfying the neuron logical constraints.
In an embodiment, the following defines lower bound on t.
In an embodiment, the following defines upper bound on t.
t−(wiα+si)≤1−α
t≤1−α+αwmin
t
max=1−α+αwmin
In an embodiment, the upper bound on t, tmax, is calculated by choosing a constraint for i where wi is chosen such that t is the maximum possible value, namely wi=wmin. The alpha value used here can be the same alpha value used in the other constraints and calculation of all derived values depending on alpha. In an embodiment, there may be one alpha value for a given logical neuron. There may be different alpha values for other logical neurons.
In an embodiment, the following defines lower bounds on x, which is the least input expected to the activation function of the logical neuron and the minimum point of the operating range of the neuron.
In an embodiment, the following defines lower bound on wmin.
In an embodiment, the following defines logical bandwidth, which is the width of the operating range of the activation function of the logical neuron. A larger logical bandwidth necessarily means a smaller gradient quality, while a lesser logical bandwidth means a smaller expressivity. The logical bandwidth is thus a measure that is used to balance gradient quality and expressivity in the system optimization.
In an embodiment, the following defines upper bound on λ (expressivity).
The above defined lower bound on t, upper bound on t, lower bounds on x, lower bound on wmin, logical bandwidth, and upper bound on λ, are used in formulating the activation optimization function.
The following illustrates activation optimization in an embodiment. The optimization maximizes ratio-average flanks gradient (expressed as g) and expressivity (expressed as λ) (activation optimization).
g represents gradients.
The following illustrates ratio-average flanks gradient in the above activation optimization. In an embodiment, the ratio-average flanks gradients is an average gradient involving two flank gradients that are ratio-averaged. In an embodiment, a piecewise linear activation function includes three connected linear lines spanning the domain of xmin to tmax and the range from 0 to 1. The left linear piece from xmin to 1−α is associated with a false output, and the center linear piece from 1−α to α is associated with fuzzy outputs, and the right linear piece from α to tmax is associated with a true output. The gradient of the left linear piece (left flank) is the range of 1−α divided by the domain width of 1−α−xmin. The gradient of the right linear piece (right flank) is the range of 1−α divided by the domain width tmax−α.
The domain width ratio of the left linear piece to the sum of the left and right linear piece is 1−α−xmin divided by the sum of 1−α−xmin and tmax−α. Similarly, the domain width ratio of the right linear piece to the sum of the left and right linear piece is tmax−α divided by the sum of 1−α−xmin and tmax−α.
The ratio-averaged flanks gradient are then the product of the gradient of the left flank (1−α)/(1−α−xmin) with the domain width ratio of the left flank, plus the product of the gradient of the right flank (1−α)/(tmax−α) with the domain width ratio of the right flank.
The derived optimization function,
incorporates maximizing of the function g, and is solved for the threshold-of-truth a value that maximizes the function with respect to expressivity value λ. In the optimization function, xmin, tmax are known, given or computed as described above.
The neuron arity and the expressivity lambda (λ) can be specified by a user. In another aspect, the neuron arity and the expressivity lambda (λ) can be predefined. The disclose system and/or method can then automatically optimize alpha via the activation objective. Knowing arity, lambda (λ) and alpha (α), the logical neuron can be fully instantiated, ready for learning of the weights. As weights adapt over time, the expressivity lambda (λ) can be recalculated to make accommodation for greater expressivity required in current weights, alpha (α) can be re-optimized when lambda (λ) changes (responsive to lambda (λ) changing).
The above formula optimizes capacity and machine learning (gradients) of real-valued logic circuits or gates. The function g combines two values of interest, the expressivity and the ratio-averaged flanks gradient of the 3-piece linear rectified activation function. In an embodiment the function g can be the multiplication between the expressivity λ and the gradient quality. The ratio-averaged flanks gradient multiplies the gradient to the ratio of each flank section width of the 3-piece linear rectified activation function to the full operating range, to obtain ratio-averaging where a thin flank section contributes less to the gradient quality measure. The activation function ƒ that maximizes the product of expressivity and gradient quality is then determined through the above formula, which provides logical neurons with an activation function that can support weights of different magnitudes up to the expressivity λ while also providing relatively non-small gradients over the entire operating range of the logical neuron.
In an embodiment, the above activation objective can be written in terms of lambda (λ), alpha (α) and arity alone. The activation objective scalar output can be calculated, if given lambda (λ), alpha (α) and arity, which indicates a relative number of the expressivity and gradient quality. Arity can be pre-specified for a logical neuron design, and the maximum expressivity lambda (λ) that the user would like to have supported by the logical neuron can also be specified. When given lambda (λ) and arity this leaves threshold-of-truth alpha (α) as the dependent parameter that can be chosen to maximize the activation objective, where this choice can be automatically determined.
In another aspect, an interface such as a user interface (e.g., shown in
At 406, the method can include defining logical constraints associated with the weighted real-valued logic gate in terms of weights associated with inputs to the neuron, a threshold-of-truth, and a neuron threshold for activation. At 408, the method can include determining the threshold-of-truth as a parameter used in an activation function of the neuron. The threshold-of-truth can be determined by solving an activation optimization formulated based on the logical constraints. The activation optimization maximizes a product of expressivity representing a distribution width of input weights to the neuron and gradient quality for the neuron given the operator arity and the maximum expressivity. In an embodiment, the gradient quality is a relative scalar measure, which can be expressed in terms of ratio-averaged flanks gradient. The ratio-averaged flanks gradient can be determined as described above. At 410, the method can include training the neural network of logical neurons using the activation function at the neuron, the activation function using the determined threshold-of-truth.
In an embodiment, the activation function can be a sigmoid function. In another embodiment, the activation function can be a 3-piece leaky rectified linear unit (ReLU). Other activation functions can be used or selected.
In an embodiment, the method can include defining or deriving using the defined logical constraints, a lower bound on the neuron threshold, an upper bound on the neuron threshold, a lower bound on the neuron's input representing a minimum point of an operating range of the neuron, a lower bound on minimum input weight in terms of the expressivity, operator arity and the threshold-of-truth, a logical bandwidth representing a width of the operating range of the activation function of the neuron, ad an upper bound on the expressivity. The activation optimization can be formulated based on the lower bound on the neuron threshold, the upper bound on the neuron threshold, the lower bound on the neuron's input, the lower bound on minimum input weight, the logical bandwidth and the upper bound on the expressivity. The activation optimization can be derived in terms of the expressivity, the threshold-of-truth, the lower bound on the neuron's input and the upper bound of the maximum input expected for the neuron activation.
The method may also include continually updating the activation function for the threshold-of-truth value to optimize gradients of the activation function over a logical operating range by forming a piecewise linear function that is false at an operating range minimum, at threshold-of-falsity for a threshold-of-falsity input, at threshold-of-truth for a threshold-of-truth input, and true at the operating range maximum.
The method can also include introducing a slack variable associated with the neuron's input to allow the neuron's input to be removed without requiring higher expressivity. In an embodiment, the sum of the input weights to the neuron can be determined given only a minimum weight and the expressivity. In embodiment, the threshold-of-truth can be updated based on a current expressivity. In an embodiment, the method can also include visualizing properties of the weighted real-valued logic gate.
The computer system may be described in the general context of computer system executable instructions, such as program modules, being executed by a computer system. Generally, program modules may include routines, programs, objects, components, logic, data structures, and so on that perform particular tasks or implement particular abstract data types. The computer system may be practiced in distributed cloud computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed cloud computing environment, program modules may be located in both local and remote computer system storage media including memory storage devices.
The components of computer system may include, but are not limited to, one or more processors or processing units 12, a system memory 16, and a bus 14 that couples various system components including system memory 16 to processor 12. The processor 12 may include a module 30 that performs the methods described herein. The module 30 may be programmed into the integrated circuits of the processor 12, or loaded from memory 16, storage device 18, or network 24 or combinations thereof.
Bus 14 may represent one or more of any of several types of bus structures, including a memory bus or memory controller, a peripheral bus, an accelerated graphics port, and a processor or local bus using any of a variety of bus architectures. By way of example, and not limitation, such architectures include Industry Standard Architecture (ISA) bus, Micro Channel Architecture (MCA) bus, Enhanced ISA (EISA) bus, Video Electronics Standards Association (VESA) local bus, and Peripheral Component Interconnects (PCI) bus.
Computer system may include a variety of computer system readable media. Such media may be any available media that is accessible by computer system, and it may include both volatile and non-volatile media, removable and non-removable media.
System memory 16 can include computer system readable media in the form of volatile memory, such as random access memory (RAM) and/or cache memory or others. Computer system may further include other removable/non-removable, volatile/non-volatile computer system storage media. By way of example only, storage system 18 can be provided for reading from and writing to a non-removable, non-volatile magnetic media (e.g., a “hard drive”). Although not shown, a magnetic disk drive for reading from and writing to a removable, non-volatile magnetic disk (e.g., a “floppy disk”), and an optical disk drive for reading from or writing to a removable, non-volatile optical disk such as a CD-ROM, DVD-ROM or other optical media can be provided. In such instances, each can be connected to bus 14 by one or more data media interfaces.
Computer system may also communicate with one or more external devices 26 such as a keyboard, a pointing device, a display 28, etc.; one or more devices that enable a user to interact with computer system; and/or any devices (e.g., network card, modem, etc.) that enable computer system to communicate with one or more other computing devices. Such communication can occur via Input/Output (I/O) interfaces 20.
Still yet, computer system can communicate with one or more networks 24 such as a local area network (LAN), a general wide area network (WAN), and/or a public network (e.g., the Internet) via network adapter 22. As depicted, network adapter 22 communicates with the other components of computer system via bus 14. It should be understood that although not shown, other hardware and/or software components could be used in conjunction with computer system. Examples include, but are not limited to: microcode, device drivers, redundant processing units, external disk drive arrays, RAID systems, tape drives, and data archival storage systems, etc.
The present invention may be a system, a method, and/or a computer program product at any possible technical detail level of integration. The computer program product may include a computer readable storage medium (or media) having computer readable program instructions thereon for causing a processor to carry out aspects of the present invention.
The computer readable storage medium can be a tangible device that can retain and store instructions for use by an instruction execution device. 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 suitable combination of the foregoing. A non-exhaustive list of more specific examples of the computer readable storage medium includes the following: a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), a static random access memory (SRAM), a portable compact disc read-only memory (CD-ROM), a digital versatile disk (DVD), a memory stick, a floppy disk, a mechanically encoded device such as punch-cards or raised structures in a groove having instructions recorded thereon, and any suitable combination of the foregoing. A computer readable storage medium, as used herein, 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 herein can be downloaded to respective computing/processing devices from α 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 may comprise 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 storage medium within the respective computing/processing device.
Computer readable program instructions for carrying out operations of the present invention may be assembler instructions, instruction-set-architecture (ISA) instructions, machine instructions, machine dependent instructions, microcode, firmware instructions, state-setting data, configuration data for integrated circuitry, or either source code or object code written in any combination of one or more programming languages, including an object oriented programming language such as Smalltalk, C++, or the like, and procedural programming languages, such as the “C” programming language or similar programming languages. The computer readable program instructions may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider). 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 utilizing state information of the computer readable program instructions to personalize the electronic circuitry, in order to perform aspects of the present invention.
Aspects of the present invention are described herein with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems), and computer program products according to embodiments of the invention. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer readable program instructions.
These computer readable program instructions may be provided to a processor of a computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, create means for implementing the functions/acts specified in the flowchart and/or block diagram block or blocks. These computer readable program instructions may also be stored in a computer readable storage medium that can direct a computer, a programmable data processing apparatus, and/or other devices to function in a particular manner, such that the computer readable storage medium having instructions stored therein comprises an article of manufacture including instructions which implement aspects of the function/act specified in the flowchart and/or block diagram block or blocks.
The computer readable program instructions may also be loaded onto a computer, other programmable data processing 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/acts specified in the flowchart and/or block diagram block or blocks.
The flowchart and block diagrams in the Figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods, and computer program products according to various embodiments of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of instructions, which comprises one or more executable instructions for implementing the specified logical function(s). In some alternative implementations, the functions noted in the blocks may occur out of the order noted in the Figures. For example, two blocks shown in succession may, in fact, be accomplished as one step, executed concurrently, substantially concurrently, in a partially or wholly temporally overlapping manner, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be 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 acts or carry out combinations of special purpose hardware and computer instructions.
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the invention. As used herein, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. As used herein, the term “or” is an inclusive operator and can mean “and/or”, unless the context explicitly or clearly indicates otherwise. It will be further understood that the terms “comprise”, “comprises”, “comprising”, “include”, “includes”, “including”, and/or “having,” when used herein, can specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof. As used herein, the phrase “in an embodiment” does not necessarily refer to the same embodiment, although it may. As used herein, the phrase “in one embodiment” does not necessarily refer to the same embodiment, although it may. As used herein, the phrase “in another embodiment” does not necessarily refer to a different embodiment, although it may. Further, embodiments and/or components of embodiments can be freely combined with each other unless they are mutually exclusive.
The corresponding structures, materials, acts, and equivalents of all means or step plus function elements, if any, in the claims below are intended to include any structure, material, or act for performing the function in combination with other claimed elements as specifically claimed. The description of the present invention has been presented for purposes of illustration and description, but is not intended to be exhaustive or limited to the invention in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the invention. The embodiment was chosen and described in order to best explain the principles of the invention and the practical application, and to enable others of ordinary skill in the art to understand the invention for various embodiments with various modifications as are suited to the particular use contemplated.
This application is related to commonly-owned, co-pending U.S. Provisional Application No. ______ (Attorney Docket P202000680US01) entitled, “FIRST-ORDER LOGICAL NEURAL NETWORKS WITH BIDIRECTIONAL INFERENCE”, filed on even date, the entire content and disclosure of which is expressly incorporated by reference herein as if fully set forth herein.