Skip to content

Commit

Permalink
Merge branch 'main' into feature/plan-utils
Browse files Browse the repository at this point in the history
  • Loading branch information
SemyonSinchenko committed Nov 23, 2023
2 parents ca903a8 + b4263aa commit 501337a
Show file tree
Hide file tree
Showing 3 changed files with 58 additions and 1 deletion.
6 changes: 5 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -30,4 +30,8 @@ site
.vscode

# Emacs
.dir_locals.el
.dir_locals.el

# Jupyter notebooks
*.ipynb
.ipynb_checkpoints
52 changes: 52 additions & 0 deletions quinn/math.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,52 @@
"""Math routines for PySpark."""
from __future__ import annotations

from typing import Optional, Union

from pyspark.sql import Column
from pyspark.sql import functions as F # noqa: N812


def rand_laplace(
mu: Union[float, Column],
beta: Union[float, Column],
seed: Optional[int] = None,
) -> Column:
"""Generate random numbers from Laplace(mu, beta).
:param mu: mu parameter of Laplace distribution
:param beta: beta parameter of Laplace distribution
:param seed: random seed value (optional, default None)
:returns: column with random numbers
"""
if not isinstance(mu, Column):
mu = F.lit(mu)

if not isinstance(beta, Column):
beta = F.lit(beta)

u = F.rand(seed)

return (
F.when(u < F.lit(0.5), mu + beta * F.log(2 * u))
.otherwise(mu - beta * F.log(2 * (1 - u)))
.alias("laplace_random")
)


def div_or_else(
cola: Column,
colb: Column,
default: Union[float, Column] = 0.0,
) -> Column:
"""Return result of division of cola by colb or default if colb is zero.
:param cola: dividend
:param colb: divisor
:param default: default value
:returns: result of division or zero
"""
if not isinstance(default, Column):
default = F.lit(default)

return F.when(colb == F.lit(0.0), default).otherwise(cola / colb)
1 change: 1 addition & 0 deletions quinn/schema_helpers.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@

import json
from typing import Optional

from pyspark.sql import SparkSession
from pyspark.sql import types as T # noqa: N812

Expand Down

0 comments on commit 501337a

Please sign in to comment.