lib/rumale/linear_model/lasso.rb in rumale-0.10.0 vs lib/rumale/linear_model/lasso.rb in rumale-0.11.0

- old
+ new

@@ -39,16 +39,21 @@ # @param bias_scale [Float] The scale of the bias term. # @param max_iter [Integer] The maximum number of iterations. # @param batch_size [Integer] The size of the mini batches. # @param optimizer [Optimizer] The optimizer to calculate adaptive learning rate. # If nil is given, Nadam is used. + # @param n_jobs [Integer] The number of jobs for running the fit method in parallel. + # If nil is given, the method does not execute in parallel. + # If zero or less is given, it becomes equal to the number of processors. + # This parameter is ignored if the Parallel gem is not loaded. # @param random_seed [Integer] The seed value using to initialize the random generator. - def initialize(reg_param: 1.0, fit_bias: false, bias_scale: 1.0, max_iter: 1000, batch_size: 10, optimizer: nil, random_seed: nil) + def initialize(reg_param: 1.0, fit_bias: false, bias_scale: 1.0, max_iter: 1000, batch_size: 10, optimizer: nil, + n_jobs: nil, random_seed: nil) check_params_float(reg_param: reg_param, bias_scale: bias_scale) check_params_integer(max_iter: max_iter, batch_size: batch_size) check_params_boolean(fit_bias: fit_bias) - check_params_type_or_nil(Integer, random_seed: random_seed) + check_params_type_or_nil(Integer, n_jobs: n_jobs, random_seed: random_seed) check_params_positive(reg_param: reg_param, max_iter: max_iter, batch_size: batch_size) super end # Fit the model with given training data. @@ -65,14 +70,18 @@ n_features = x.shape[1] if n_outputs > 1 @weight_vec = Numo::DFloat.zeros(n_outputs, n_features) @bias_term = Numo::DFloat.zeros(n_outputs) - n_outputs.times { |n| @weight_vec[n, true], @bias_term[n] = partial_fit(x, y[true, n]) } + if enable_parallel? + models = parallel_map(n_outputs) { |n| partial_fit(x, y[true, n]) } + n_outputs.times { |n| @weight_vec[n, true], @bias_term[n] = models[n] } + else + n_outputs.times { |n| @weight_vec[n, true], @bias_term[n] = partial_fit(x, y[true, n]) } + end else @weight_vec, @bias_term = partial_fit(x, y) end - self end # Predict values for samples. #