log()#
relationalai.std.math
#log(x: Number|Producer, base: Number|Producer|None = None) -> Expression
Calculates the logarithm of x
with the specified base
.
If base
is None
, the natural logarithm (base e
) is used.
If x
or base
is a Producer
, log()
filters out any non-numeric or negative values from the producer.
Must be called in a rule or query context.
Parameters#
Name | Type | Description |
---|---|---|
x | Producer or Python Number object | The number to take the logarithm of. |
base | Producer or Python Number object or None | The base of the logarithm. If None , the natural logarithm (base e ) is used. |
Returns#
An Expression
object.
Example#
Use log()
to calculate the logarithm of a number with a specified base:
#import relationalai as rai
from relationalai.std import math
# =====
# SETUP
# =====
model = rai.Model("MyModel")
Person = model.Type("Person")
with model.rule():
Person.add(id=1).set(name="Alice", age=9)
Person.add(id=2).set(name="Bob", age=-10) # Negative age
Person.add(id=3).set(name="Carol", age="INVALID") # Non-numeric age
# =======
# EXAMPLE
# =======
# Set age_log and age_log2 properties to the natural and base-2 logarithms of
# each person’s age.
with model.rule():
person = Person()
person.set(age_log=math.log(person.age))
person.set(age_log2=math.log(person.age, base=2))
# Since log() filters out negative and non-numeric values, the age_log and
# age_log2 properties are not set for Bob or Carol.
with model.query() as select:
person = Person()
response = select(person.id, person.name, person.age_log2)
print(response.results)
# id name age_log2
# 0 1 Alice 3.169925
# 1 2 Bob NaN
# 2 3 Carol NaN