Sha256: d4db26ca94dcb7cfb9b431a2322cfbf0a420f57f558ab95da84502411de410ab

Contents?: true

Size: 1.04 KB

Versions: 2

Compression:

Stored size: 1.04 KB

Contents

# frozen_string_literal: true

module Suika
  # @!visibility private
  class Lattice
    # @!visibility private
    Node = Struct.new(:surface, :unknown, :min_cost, :min_prev, :left_id, :right_id, :cost, :attrs, keyword_init: true)

    attr_reader :begin_nodes, :end_nodes, :length

    # @!visibility private
    def initialize(length)
      @length = length
      @begin_nodes = Array.new(length + 1) { [] }
      @end_nodes = Array.new(length + 1) { [] }
      bos = Node.new(surface: 'BOS', unknown: false, left_id: 0, right_id: 0, cost: 0, attrs: [])
      @end_nodes[0].append(bos)
      eos = Node.new(surface: 'EOS', unknown: false, left_id: 0, right_id: 0, cost: 0, attrs: [])
      @begin_nodes[length].append(eos)
    end

    # @!visibility private
    def insert(begin_id, end_id, surface, unknown, left_id, right_id, cost, attrs)
      node = Node.new(surface: surface, unknown: unknown, left_id: left_id, right_id: right_id, cost: cost, attrs: attrs)
      @begin_nodes[begin_id].append(node)
      @end_nodes[end_id].append(node)
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
suika-0.1.4 lib/suika/lattice.rb
suika-0.1.3 lib/suika/lattice.rb