Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Appearance settings

Adversing/LeviCivita.cpp

Open more actions menu

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 

Repository files navigation

LeviCivita.cpp

A simple approach to the Levi-Civita tensor.

📚 Example Usage:

#include "levi_civita.hpp"
#include <iostream>
#include <iomanip>

void printTensorValue(const tensor::LeviCivita& tensor, const std::vector<size_t>& indices) {
    std::cout << "ε_";
    for (size_t idx : indices) {
        std::cout << (idx + 1);
    }
    std::cout << " = " << (int)tensor.get(indices) << std::endl;
}

int main() {
    try {
        // Test 2D tensor
        tensor::LeviCivita tensor2d(2);
        std::cout << "2D Levi-Civita tensor:\n";
        printTensorValue(tensor2d, {0, 1});
        printTensorValue(tensor2d, {1, 0});
        printTensorValue(tensor2d, {0, 0});
        
        std::cout << "\n3D Levi-Civita tensor:\n";
        // Test 3D tensor
        tensor::LeviCivita tensor3d(3);
        printTensorValue(tensor3d, {0, 1, 2});
        printTensorValue(tensor3d, {1, 2, 0});
        printTensorValue(tensor3d, {2, 0, 1});
        printTensorValue(tensor3d, {1, 0, 2});
        printTensorValue(tensor3d, {0, 2, 1});
        printTensorValue(tensor3d, {2, 1, 0});
        printTensorValue(tensor3d, {0, 0, 1});
        
        std::cout << "\n4D Levi-Civita tensor:\n";
        // Test 4D tensor
        tensor::LeviCivita tensor4d(4);
        printTensorValue(tensor4d, {0, 1, 2, 3});
        printTensorValue(tensor4d, {3, 2, 1, 0});
        printTensorValue(tensor4d, {0, 1, 1, 2});

    } catch (const std::exception& e) {
        std::cerr << "Error: " << e.what() << std::endl;
        return 1;
    }
    
    return 0;
}

Releases

No releases published

Packages

No packages published

Languages

Morty Proxy This is a proxified and sanitized view of the page, visit original site.