Class: RedShift::DVectorFloat
- Includes:
- Enumerable
- Defined in:
- ext/redshift/dvector-float/dvector-float.rb
Overview
A linear collection of single-precision floats.
Intended primarily for access from C code, using the inline rs_dvf_push() and rs_dvf_pop() functions.
Implements some of the same methods as Array, but not all.
Like an Array, a DVector grows implicitly as elements are pushed. But unlike an Array, a DVector shrinks only explicitly. This is to minimize realloc() calls when a DVector rapidly grows and shrinks.
Class Method Summary collapse
Instance Method Summary collapse
- #==(other) ⇒ Object
- #_dump_data ⇒ Object
- #_load_data(from_array) ⇒ Object
- #dup ⇒ Object
- #each ⇒ Object
- #eql?(other) ⇒ Boolean
- #hash ⇒ Object
-
#initialize(elts = nil) ⇒ DVectorFloat
constructor
A new instance of DVectorFloat.
- #inspect ⇒ Object
- #length ⇒ Object (also: #size)
- #pop ⇒ Object
- #push(*args) ⇒ Object (also: #<<)
- #to_a ⇒ Object
- #to_s ⇒ Object
Constructor Details
#initialize(elts = nil) ⇒ DVectorFloat
Returns a new instance of DVectorFloat.
23 24 25 |
# File 'ext/redshift/dvector-float/dvector-float.rb', line 23 def initialize(elts=nil) push(*elts) if elts end |
Class Method Details
.[](*elts) ⇒ Object
19 20 21 |
# File 'ext/redshift/dvector-float/dvector-float.rb', line 19 def self.[](*elts) new elts end |
Instance Method Details
#==(other) ⇒ Object
101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 |
# File 'ext/redshift/dvector-float/dvector-float.c', line 101 static VALUE dvf_method_equal(VALUE self, VALUE other) { int i; RS_DVectorFloat *dvf1, *dvf2; if (self == other) return Qtrue; if (CLASS_OF(self) != CLASS_OF(other)) return Qfalse; Data_Get_Struct(self, RS_DVectorFloat, dvf1); Data_Get_Struct(other, RS_DVectorFloat, dvf2); if (dvf1->len != dvf2->len) return Qfalse; for (i=0; i < dvf1->len; i++) { if (dvf1->ptr[i] != dvf2->ptr[i]) return Qfalse; } return Qtrue; } |
#_dump_data ⇒ Object
76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 |
# File 'ext/redshift/dvector-float/dvector-float.c', line 76 static VALUE dvf_method_to_a(VALUE self) { int i; RS_DVectorFloat *dvf; VALUE ary; Data_Get_Struct(self, RS_DVectorFloat, dvf); ary = rb_ary_new(); if (!dvf->ptr) return ary; for (i=0; i < dvf->len; i++) { rb_ary_push(ary, rb_float_new(dvf->ptr[i])); } return ary; } |
#_load_data(from_array) ⇒ Object
148 149 150 151 152 153 154 155 156 157 158 159 |
# File 'ext/redshift/dvector-float/dvector-float.c', line 148 static VALUE dvf_method_load_data(VALUE self, VALUE from_array) { long i; RS_DVectorFloat *dvf; Data_Get_Struct(self, RS_DVectorFloat, dvf); for (i=0; i < RARRAY_LEN(from_array); i++) { rs_dvf_push(dvf, NUM2DBL(RARRAY_PTR(from_array)[i])); } return self; } |
#dup ⇒ Object
30 31 32 |
# File 'ext/redshift/dvector-float/dvector-float.rb', line 30 def dup self.class.new to_a end |
#each ⇒ Object
61 62 63 64 65 66 67 68 69 70 71 72 73 74 |
# File 'ext/redshift/dvector-float/dvector-float.c', line 61 static VALUE dvf_method_each(VALUE self) { long i; RS_DVectorFloat *dvf; Data_Get_Struct(self, RS_DVectorFloat, dvf); RETURN_ENUMERATOR(self, 0, 0); for (i=0; i < dvf->len; i++) { rb_yield(rb_float_new(dvf->ptr[i])); } return self; } |
#eql?(other) ⇒ Boolean
101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 |
# File 'ext/redshift/dvector-float/dvector-float.c', line 101 static VALUE dvf_method_equal(VALUE self, VALUE other) { int i; RS_DVectorFloat *dvf1, *dvf2; if (self == other) return Qtrue; if (CLASS_OF(self) != CLASS_OF(other)) return Qfalse; Data_Get_Struct(self, RS_DVectorFloat, dvf1); Data_Get_Struct(other, RS_DVectorFloat, dvf2); if (dvf1->len != dvf2->len) return Qfalse; for (i=0; i < dvf1->len; i++) { if (dvf1->ptr[i] != dvf2->ptr[i]) return Qfalse; } return Qtrue; } |
#hash ⇒ Object
119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 |
# File 'ext/redshift/dvector-float/dvector-float.c', line 119 static VALUE dvf_method_hash(VALUE self) { long i, h; RS_DVectorFloat *dvf; Data_Get_Struct(self, RS_DVectorFloat, dvf); h = dvf->len; for (i=0; i < dvf->len; i++) { int hash; unsigned int j; char *c; float f; h = (h << 1) | (h<0 ? 1 : 0); f = dvf->ptr[i]; if (f == 0) f = fabs(f); c = (char*)&f; for (hash=0, j=0; j<sizeof(float); j++) { hash = (hash * 971) ^ (unsigned char)c[j]; } if (hash < 0) hash = -hash; h ^= hash; } return LONG2FIX(h); } |
#inspect ⇒ Object
27 |
# File 'ext/redshift/dvector-float/dvector-float.rb', line 27 def inspect; to_a.inspect; end |
#length ⇒ Object Also known as: size
94 95 96 97 98 99 |
# File 'ext/redshift/dvector-float/dvector-float.c', line 94 static VALUE dvf_method_length(VALUE self) { RS_DVectorFloat *dvf; Data_Get_Struct(self, RS_DVectorFloat, dvf); return INT2NUM(dvf->len); } |
#pop ⇒ Object
52 53 54 55 56 57 58 59 |
# File 'ext/redshift/dvector-float/dvector-float.c', line 52 static VALUE dvf_method_pop(VALUE self) { RS_DVectorFloat *dvf; Data_Get_Struct(self, RS_DVectorFloat, dvf); return dvf->len == 0 ? Qnil : rb_float_new(rs_dvf_pop(dvf)); } |
#push(*args) ⇒ Object Also known as: <<
38 39 40 41 42 43 44 45 46 47 48 49 50 |
# File 'ext/redshift/dvector-float/dvector-float.c', line 38 static VALUE dvf_method_push(int argc, VALUE *argv, VALUE self) { int i; RS_DVectorFloat *dvf; Data_Get_Struct(self, RS_DVectorFloat, dvf); for (i = 0; i < argc; i++) { rs_dvf_push(dvf, NUM2DBL(argv[i])); } return self; } |
#to_a ⇒ Object
76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 |
# File 'ext/redshift/dvector-float/dvector-float.c', line 76 static VALUE dvf_method_to_a(VALUE self) { int i; RS_DVectorFloat *dvf; VALUE ary; Data_Get_Struct(self, RS_DVectorFloat, dvf); ary = rb_ary_new(); if (!dvf->ptr) return ary; for (i=0; i < dvf->len; i++) { rb_ary_push(ary, rb_float_new(dvf->ptr[i])); } return ary; } |
#to_s ⇒ Object
28 |
# File 'ext/redshift/dvector-float/dvector-float.rb', line 28 def to_s; to_a.to_s; end |