// Matrix Construct
//
// Copyright (C) Matrix Construct Developers, Authors & Contributors
// Copyright (C) 2016-2021 Jason Volk <jason@zemos.net>
//
// Permission to use, copy, modify, and/or distribute this software for any
// purpose with or without fee is hereby granted, provided that the above
// copyright notice and this permission notice is present in all copies. The
// full license for this software is available in the LICENSE file.

#pragma once
#define HAVE_IRCD_GPT_TOKEN_H

union ircd_gpt_token
{
	float
	word[768],
	attn[12][64];
};

#ifdef __OPENCL_C_VERSION__
union ircd_gpt_tokenv
{
	float4
	word[768/4],
	attn[12][64/4];

	union ircd_gpt_token
	token;
};
#endif

struct ircd_gpt_attn_qkv
{
	union ircd_gpt_token
	qry,
	key,
	val;
};

#ifdef __OPENCL_C_VERSION__
struct ircd_gpt_attn_qkvv
{
	union ircd_gpt_tokenv
	qry,
	key,
	val;
};
#endif

union ircd_gpt_attn_aperature
{
	float
	fcon[2304],
	proj[3][768],
	qkv[3][12][64];

	union ircd_gpt_token
	token[3];
};

#ifdef __OPENCL_C_VERSION__
union ircd_gpt_attn_aperaturev
{
	float4
	fcon[2304/4],
	proj[3][768/4],
	qkv[3][12][64/4];

	union ircd_gpt_token_f32x4
	token[3];
};

union ircd_gpt_attn_aperature_f32x8
{
	float8
	fcon[2304/8],
	proj[3][768/8],
	qkv[3][12][64/8];

	union ircd_gpt_token_f32x8
	token[3];
};

union ircd_gpt_attn_aperature_f32x16
{
	float16
	fcon[2304/16],
	proj[3][768/16],
	qkv[3][12][64/16];

	union ircd_gpt_token_f32x16
	token[3];
};
#endif

union ircd_gpt_ffnn_aperature
{
	float
	fcon[3072],
	proj[4][768];

	union ircd_gpt_token
	token[4];
};

#ifdef __OPENCL_C_VERSION__
union ircd_gpt_ffnn_aperaturev
{
	float4
	fcon[3072/4],
	proj[4][768/4];

	union ircd_gpt_token_f32x4
	token[4];
};

union ircd_gpt_ffnn_aperature_f32x8
{
	float8
	fcon[3072/8],
	proj[4][768/8];

	union ircd_gpt_token_f32x4
	token[4];
};

union ircd_gpt_ffnn_aperature_f32x16
{
	float16
	fcon[3072/16],
	proj[4][768/16];

	union ircd_gpt_token_f32x4
	token[4];
};
#endif