12,692,778 members (35,349 online)
Add your own
alternative version

84.3K views
1.7K downloads
27 bookmarked
Posted

# Tensor templates

, 26 Jun 2001
 Rate this:
Please Sign up or sign in to vote.
A template class that enable you to make tensors with any dimensionality. Process convolution of any tensors and so on.
<!-- Download Links -->

## Introduction

The `Tensor` class was written in 1997 during my study of templates (I found it examining my archives).

But I've not seen any such classes since. So I think it can be useful for students. The main reason I've wrote it - for the convolution of tensors with any dimensionality. Also you can get and use any sub-tensor using `operator[]`, for example can be written like

```Tensor2 qq,a1,a2,aa;
convolution(aa["li"],a2["lj"],qq["ij"]);
convolution(qq["kl"],a1["ki"],aa["li"]);```

## Using

The demo project shows usage of tensors. You can:

Declare and init tensors (you should specify dimension and indexes range).

```Tensor2 result2(2);
Tensor4 tt(3);  // 4 - dimensions indexes can be 0-2 or "1"-"3"
Tensor2 t1(2);       t1[0][0] = 1.0;
t1[1][0] = 2.0;
t1[0][1] = 3.0;
t1[1][1] = 4.0;
```

Convolute tensors - note that you can use different dimensions and one or more constants in indices.

```convolution(result5["2i"],t3["2"],t2["i3"]);
convolution(result6["ij"],t1["ja"],t2["ai"]);
```

Use some arithmetical operations.

```result3 = t1 + t2*2;
```

Print part or whole tensor.

```t4["ijkl"].printf(std::cout);
result5["1j"].printf(std::cout);
```

Average tensors.

```Tensor2 t[2];
double q[2];
t2.averaging(&t[0],q,2);
```

Invert 4-dimension tensor with indexes (0,1).

```Tensor4 t(2),ti(2);
ti = inverse(t);
```

## To Do list

It can be easy to implement some more operations with tensors (different multiplication and so). Please let me know, if you need some.

## Note

Make sure to check out the my web site which is more likely to have updates and betas: http://www.zmike.net

## License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here

## About the Author

 Web Developer Russian Federation
Mike has been programming in C/C++ for 11 years and Visual C++/MFC for 4 years. His background includes pure and applied mathematics, engineering and physics, and he is currently based in Moscow, Russia.

## Comments and Discussions

 First Prev Next
 linear algebra VeganFanatic9-Jun-10 16:22 VeganFanatic 9-Jun-10 16:22
 Introduction to Tensor Convolution Pho3NiX15-Aug-09 8:52 Pho3NiX 15-Aug-09 8:52
 General comment Darid Tromer25-Feb-08 0:08 Darid Tromer 25-Feb-08 0:08
 Re: General comment Mike Melnikov1-Mar-08 1:26 Mike Melnikov 1-Mar-08 1:26
 [Message Deleted] Danny Rodriguez27-Jan-08 10:41 Danny Rodriguez 27-Jan-08 10:41
 this is good! yulin1114-Jun-07 4:50 yulin11 14-Jun-07 4:50
 Tensors, great fun! ;) PedroMC11-Aug-05 0:48 PedroMC 11-Aug-05 0:48
 Re: Tensors, great fun! ;) yulin1114-Jun-07 4:52 yulin11 14-Jun-07 4:52
 thk u syit31515-May-04 5:37 syit315 15-May-04 5:37
 pcfan on line.
 Well Done ! Colin Davies6-Jul-02 1:42 Colin Davies 6-Jul-02 1:42
 Re: Well Done ! Mike Melnikov10-Aug-02 4:11 Mike Melnikov 10-Aug-02 4:11
 I'm ashamed to ask but... Daniel Turini22-Dec-01 5:17 Daniel Turini 22-Dec-01 5:17
 Re: I'm ashamed to ask but... Mike Melnikov26-Dec-01 22:01 Mike Melnikov 26-Dec-01 22:01
 Re: I'm ashamed to ask but... Jerry Jeremiah14-Mar-06 14:56 Jerry Jeremiah 14-Mar-06 14:56
 Last Visit: 31-Dec-99 19:00     Last Update: 17-Jan-17 22:36 Refresh 1

General    News    Suggestion    Question    Bug    Answer    Joke    Praise    Rant    Admin

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

| Advertise | Privacy | Terms of Use | Mobile
Web02 | 2.8.170118.1 | Last Updated 27 Jun 2001
Article Copyright 2001 by Mike Melnikov
Everything else Copyright © CodeProject, 1999-2017
Layout: fixed | fluid