interface ngraph::snippets::TargetMachine

Overview

Base class Target machine representation. Target derives from this class to provide generator information about supported emittors. More…

#include <generator.hpp>

template TargetMachine
{
    // methods

    virtual bool is_supported() const = 0;
    virtual code get_snippet() const = 0;
    virtual size_t get_lanes() const = 0;
    std::function<std::shared_ptr<Emitter>(std::shared_ptr<ngraph::Node>)> get(const ngraph::DiscreteTypeInfo type) const;
    bool has(const ngraph::DiscreteTypeInfo type) const;
};

Detailed Documentation

Base class Target machine representation. Target derives from this class to provide generator information about supported emittors.

Methods

virtual bool is_supported() const = 0

checks if target is natively supported

Returns:

true, if supported

virtual code get_snippet() const = 0

finalizes code generation

Returns:

generated kernel binary

virtual size_t get_lanes() const = 0

gets number of lanes supported by target’s vector ISA

Returns:

number of lanes

std::function<std::shared_ptr<Emitter>(std::shared_ptr<ngraph::Node>)> get(const ngraph::DiscreteTypeInfo type) const

called by generator to all the emittor for a target machine

Returns:

a map by node’s type info with callbacks to create an instance of emmitter for corresponding operation type

bool has(const ngraph::DiscreteTypeInfo type) const

checks if emitter for a specific operation is supported

Returns:

true, if supported