AgentSkillsCN

pyrolite

针对火成岩、变质岩与沉积岩开展地球化学数据分析与可视化。当Claude需要执行以下操作时使用:(1) 为成分数据创建三元图;(2) 绘制经过归一化的稀土元素蜘蛛图;(3) 构建TAS或其他分类图;(4) 对成分数据应用对数比变换;(5) 计算CIPW规范;(6) 生成Harker变异图;(7) 计算元素比值与异常值。

SKILL.md
--- frontmatter
name: pyrolite
description: |
  Geochemistry data analysis and visualization for igneous, metamorphic, and
  sedimentary rocks. Use when Claude needs to: (1) Create ternary diagrams for
  compositional data, (2) Plot REE spider diagrams with normalization, (3) Build
  TAS or other classification diagrams, (4) Apply log-ratio transforms to
  compositional data, (5) Calculate CIPW norms, (6) Generate Harker variation
  diagrams, (7) Compute element ratios and anomalies.

pyrolite - Geochemistry Analysis

Quick Reference

python
import pandas as pd
import matplotlib.pyplot as plt
from pyrolite.geochem.norm import get_reference_composition

df = pd.read_csv('samples.csv')
df.pyrochem   # Geochemistry methods
df.pyrocomp   # Compositional methods

# Normalize and plot REE
chondrite = get_reference_composition('Chondrite_McDonough1995')
ax = df.pyrochem.normalize_to(chondrite, units='ppm').pyroplot.REE(unity_line=True)

Key Modules

ModulePurpose
pyrolite.plotTernary, spider diagrams
pyrolite.geochem.normNormalization references
pyrolite.compCLR, ALR, ILR transforms
pyrolite.plot.templatesTAS, Pearce diagrams
pyrolite.mineral.normativeCIPW norm

Essential Operations

Ternary Diagram

python
ax = df[['SiO2', 'CaO', 'Na2O']].pyroplot.scatter(c='k', s=50)

TAS Diagram

python
from pyrolite.plot.templates import TAS
df['Na2O_K2O'] = df['Na2O'] + df['K2O']
ax = TAS()
ax.scatter(df['SiO2'], df['Na2O_K2O'], c='red', s=50)

REE Pattern

python
chondrite = get_reference_composition('Chondrite_McDonough1995')
ax = df.pyrochem.normalize_to(chondrite, units='ppm').pyroplot.REE(unity_line=True)

Trace Element Spider

python
pm = get_reference_composition('PM_McDonough1995')
ax = df.pyrochem.normalize_to(pm).pyroplot.spider(unity_line=True)

Compositional Transforms

python
df_closed = df.pyrocomp.renormalise(scale=100)  # Closure
df_clr = df.pyrocomp.CLR()   # Centered log-ratio
df_alr = df.pyrocomp.ALR()   # Additive log-ratio
df_ilr = df.pyrocomp.ILR()   # Isometric log-ratio

Element Ratios and Anomalies

python
df['La_Yb'] = df['La'] / df['Yb']                        # LREE/HREE
df['Eu_Eu*'] = df['Eu'] / (df['Sm'] * df['Gd']) ** 0.5   # Eu anomaly
lambdas = df.pyrochem.lambda_lnREE()                      # REE shape

CIPW Norm

python
from pyrolite.mineral.normative import CIPW_norm
norm = CIPW_norm(df)  # df must have major oxides in wt%

Harker Diagrams

python
fig, axes = plt.subplots(2, 3, figsize=(12, 8))
for ax, elem in zip(axes.flatten(), ['TiO2', 'Al2O3', 'FeO', 'MgO', 'CaO', 'Na2O']):
    ax.scatter(df['SiO2'], df[elem], c='blue', s=50)
    ax.set_xlabel('SiO2 (wt%)'); ax.set_ylabel(f'{elem} (wt%)')

Pearce Discrimination

python
from pyrolite.plot.templates import pearce_templates
ax = pearce_templates.YNb()
ax.scatter(df['Nb'], df['Y'], c='red', s=50)

Common Normalization References

ReferenceCodeUse For
ChondriteChondrite_McDonough1995REE patterns
Primitive MantlePM_McDonough1995Trace elements
N-MORBNMORB_SunMcDonough1989Ocean basalts
Upper CrustUCC_RudnickGao2003Crustal rocks

Tips

  1. Close compositions before analysis (ensure sum to 100%)
  2. Use log-ratios (CLR/ALR/ILR) for statistical analysis
  3. Choose appropriate normalization for spider diagrams
  4. Check for Eu anomaly (positive = cumulate, negative = fractionation)

References

Scripts