# TCI Quantum XY Model Analysis

This repository contains code for analyzing the quantum XY model using Tensor Cross Interpolation (TCI) and Gaussian Process Regression (GPR) methods. The code generates figures comparing these methods for phase diagram reconstruction and active learning tasks.

## Overview

The project implements and compares different machine learning approaches for learning quantum phase diagrams:
- **Tensor Cross Interpolation (TCI)**: Adaptive tensor approximation method
- **Gaussian Process Regression (GPR)**: Both active and passive learning variants
- **XY Model**: Exact analytic solutions for benchmarking

## Figure Generation

The code generates the following figures from the associated paper:

- **Figure 2**: TCI vs GPR benchmark comparison (`benchmark_tci_gpr.py`)
- **Figure 3**: XY model correlation length phase diagram (`hamiltonian_xy_transverse.py`)
- **Figure 4**: TCI resolution and bond dimension analysis (`benchmark_tci.py`)
- **Figure 5**: Active vs passive GPR comparison (`gpr.py`)

## Dependencies

### Required Software

This project requires the `xfac` library to be compiled from source:
- **xfac**: https://github.com/tensor4all/xfac

Please follow the installation instructions on the xfac GitHub repository to compile from source before using this code.

### Python Dependencies

The project requires the following Python packages (see `requirements.txt`):

- numpy
- matplotlib
- scikit-learn
- jax
- jaxlib
- xfacpy (from the compiled xfac library)

## Installation

1. **Install xfac from source**:
   ```bash
   git clone https://github.com/tensor4all/xfac
   cd xfac
   # Follow the compilation instructions in the xfac repository
   ```

2. **Set up conda environment**:
   ```bash
   conda create -n xfac_env python=3.9
   conda activate xfac_env
   ```

3. **Install Python dependencies**:
   ```bash
   pip install -r requirements.txt
   ```

4. **Install xfacpy**:
   Follow the Python binding installation instructions from the xfac repository.

## Usage

### Running Individual Figures

Each figure can be generated independently by running the corresponding Python file:

```bash
# Activate the conda environment
conda activate xfac_env

# Figure 2: TCI vs GPR benchmark
python benchmark_tci_gpr.py

# Figure 3: XY model correlation length
python hamiltonian_xy_transverse.py

# Figure 4: TCI resolution analysis
python benchmark_tci.py

# Figure 5: Active vs passive GPR
python gpr.py
```

### File Structure

```
├── stylesheet.py                    # Plot styling and color definitions
├── hamiltonian_xy_transverse.py    # XY model oracles and Figure 3
├── benchmark_tci_gpr.py            # TCI vs GPR comparison (Figure 2)
├── gpr.py                          # GPR active/passive learning (Figure 5)
├── benchmark_tci.py                # TCI resolution benchmark (Figure 4)
├── requirements.txt                # Python dependencies
└── README.md                       # This file
```

### Core Modules

- **`stylesheet.py`**: Contains styling parameters, colors, fonts, and plot configurations used consistently across all figures.

- **`hamiltonian_xy_transverse.py`**: Central module containing:
  - XY model gap and correlation length oracles
  - Exact analytic solutions for benchmarking
  - Figure 3 generation (2D correlation length phase diagram)

- **`benchmark_tci_gpr.py`**: Implements Figure 2, comparing TCI and GPR methods:
  - TCI active learning with quantics grids
  - Passive GPR with random sampling
  - Performance metrics and visualizations
  - Red dots with white outline for sample markers

- **`gpr.py`**: Implements Figure 5, comparing active vs passive GPR:
  - Active learning with variance-based acquisition
  - Passive random sampling baseline
  - Learning curve analysis

- **`benchmark_tci.py`**: Implements Figure 4, analyzing TCI at different resolutions:
  - Multi-resolution TCI benchmarks (6, 9, 12 bits)
  - Bond dimension analysis
  - Convergence rate comparison

## Features

- **Progress Reporting**: All scripts include detailed progress print statements showing computation status
- **Conda Environment**: Designed to work with the `xfac_env` conda environment
- **Reproducible Results**: Fixed random seeds for consistent outputs
- **Modular Design**: Central functions can be imported and reused across scripts
- **Publication-Ready Figures**: High-quality plots with consistent styling

## Configuration

### Default Parameters

- **TCI Bond Dimension**: 12-300 depending on resolution
- **GPR Budget**: 500-1000 samples
- **Grid Resolution**: Typically 2^8 = 256 points per dimension

### Customization

Parameters can be modified by editing the respective Python files or by using command-line arguments where supported (e.g., in `benchmark_tci_gpr.py`).

## Output

Each script generates:
- **PDF figures**: High-resolution publication-ready plots
- **PNG figures**: Web-compatible visualizations
- **JSON metrics**: Quantitative performance data (where applicable)
- **Progress logs**: Detailed computation progress in terminal

## Performance

- **Computation Time**: Varies from minutes to hours depending on resolution and budget
- **Memory Usage**: Moderate, scales with grid resolution
- **Parallelization**: JAX enables GPU acceleration where available

## Troubleshooting

### Common Issues

1. **xfac not found**: Ensure xfac is properly compiled and xfacpy is installed
2. **Conda environment**: Make sure `xfac_env` is activated before running scripts
3. **Memory issues**: Reduce grid resolution or system size for large computations
4. **Import errors**: Check that all dependencies in `requirements.txt` are installed

### Contact

For issues related to the xfac library, please refer to: https://github.com/tensor4all/xfac

## Citation

If you use this code, please cite the associated paper and acknowledge the xfac library:
- xfac library: https://github.com/tensor4all/xfac