\documentclass{article}
    \pagestyle{empty}

\usepackage{geometry}
\usepackage{style}
\usepackage{ragged2e}
\usepackage{pgfplots}
    \pgfplotsset{compat=newest}
    \usepgfplotslibrary{groupplots}
\usepackage{xstring}
\usepackage{underscore}

\begin{document}

\pgfplotstableread{\logpath}{\log}

\pgfplotstablegetcolsof{\log}
\pgfmathtruncatemacro{\len}{\pgfplotsretval}
\def\offset{1}
\pgfmathtruncatemacro{\elems}{\len-\offset}
\pgfmathtruncatemacro{\maxelem}{\elems-1}
\pgfmathtruncatemacro{\groups}{4}
\pgfmathtruncatemacro{\groupelems}{\len/\groups}
\pgfmathtruncatemacro{\subgroupelems}{3}
\pgfmathtruncatemacro{\groupsubgroups}{\groupelems/\subgroupelems}

\begin{figure}[h!]
\Centering
\begin{tikzpicture}

    \begin{groupplot}[group style={rows=\groups, columns=\subgroupelems, horizontal sep=2.2cm, vertical sep=1.8cm},
                      scale=0.5,
                      legend to name=leg:coordinatecheck,
                      legend columns=-1,
                      xlabel=$\zeta$,
                      xmode=log,
                      cycle multiindex* list={
                          [samples of colormap={\groupsubgroups}]\nextlist
                          mark=*\nextlist
                          % PGFPlots default (See section 4.7.7 Cycle Lists)
                          every mark/.append style={fill=.!80!black}\nextlist
                      }]

        \pgfplotsforeachungrouped \elem in {0,...,\maxelem}{
            \pgfmathtruncatemacro{\group}{mod(div(\elem,\groupelems),\groups)}
            \pgfmathtruncatemacro{\subgroupelem}{mod(div(\elem,\groupsubgroups),\subgroupelems)}
            \pgfmathtruncatemacro{\groupsubgroup}{mod(div(\elem,1),\groupsubgroups)}

            \pgfmathtruncatemacro{\groupindex}{\offset+\group*\groupelems)}

            \pgfmathtruncatemacro{\groupsubgroupindex}{\groupindex+\groupsubgroup*\subgroupelems}

            \pgfmathtruncatemacro{\subgroupelemindex}{\groupsubgroupindex+\subgroupelem}
            \pgfplotstablegetcolumnnamebyindex{\subgroupelemindex}\of{\log}\to{\subgroupelemname}
            \StrBefore[1]{\subgroupelemname}{.}[\before]
            \StrBehind[2]{\subgroupelemname}{.}[\after]
            \edef \groupsubgroupname {\before.\after}
            \StrBetween[1,2]{\subgroupelemname}{.}{.}[\subgroupelemname]
            
            \edef\tmp{
                \noexpand\ifnum \groupsubgroup = 0
                    \noexpand\nextgroupplot[title=\groupsubgroupname]
                \noexpand\fi

                \noexpand\addplot table [x=ζ, y index=\subgroupelemindex] {\logpath};
                \noexpand\addlegendentry{batch=\subgroupelemname}
            }\tmp
        }
    \end{groupplot}

    \path (group c2r1.outer north east) -- node[above]{\pgfplotslegendfromname{leg:coordinatecheck}} (group c2r1.outer north west);

\end{tikzpicture}
\end{figure}

\end{document}
