Class: SPARQL::Algebra::Operator::Rand
- Includes:
- Evaluatable
- Defined in:
- lib/sparql/algebra/operator/rand.rb
Overview
The SPARQL logical rand operator.
Returns a pseudo-random number between 0 (inclusive) and 1.0e0 (exclusive). Different numbers can be produced every time this function is invoked. Numbers should be produced with approximately equal probability.
[121] BuiltInCall ::= ... | 'RAND' NIL
Constant Summary collapse
- NAME =
:rand
Instance Method Summary collapse
-
#apply(**options) ⇒ RDF::Literal::Double
Returns a pseudo-random number between 0 (inclusive) and 1.0e0 (exclusive).
-
#to_sparql(**options) ⇒ String
Returns a partial SPARQL grammar for this operator.
Methods included from Evaluatable
#evaluate, #memoize, #replace_aggregate!, #replace_vars!
Instance Method Details
#apply(**options) ⇒ RDF::Literal::Double
Returns a pseudo-random number between 0 (inclusive) and 1.0e0 (exclusive). Different numbers can be produced every time this function is invoked. Numbers should be produced with approximately equal probability.
38 39 40 |
# File 'lib/sparql/algebra/operator/rand.rb', line 38 def apply(**) RDF::Literal::Double.new(Random.rand) end |
#to_sparql(**options) ⇒ String
Returns a partial SPARQL grammar for this operator.
Extracts projections
49 50 51 |
# File 'lib/sparql/algebra/operator/rand.rb', line 49 def to_sparql(**) "RAND()" end |