Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/urbanjost/m_sets

basic set functions
https://github.com/urbanjost/m_sets

fortran fortran-package-manager matlab sets

Last synced: 23 days ago
JSON representation

basic set functions

Awesome Lists containing this project

README

        

[![](docs/images/venn_little.gif)](https://urbanjost.github.io/M_sets/fpm-ford/index.html)
# [M_sets](https://urbanjost.github.io/M_sets/man3.html)

## Name
**M_sets**(3f) - functions reminiscent of Matlab set functions

## Description

Set-theory operations compare the elements in two sets to find
commonalities, differences, and membership.

M_set(3f) is a Fortran module comprising a small group of set-theory
functions reminiscent of related Matlab procedures.

M_set(3f) is intended to be built with and used by fpm(1) projects.
It requires M_orderpack(3f) as a dependency, which is of course
taken care of automatically via fpm(1).

Currently the allowed sets are vectors of integer numbers or arrays
of character variables. real numbers are allowed but "caveat emptor",
as comparing floats for equality has issues. You may have to condition
the float data by converting it to scaled integers or using intrinsics
such as NEAREST(3f) to produce the desired results.

## Functions
+ union(A,B,setOrder) - Join two sets and remove duplicates of values
+ unique(A,setOrder) - Remove duplicates of values from a set
+ intersect(A,B,setOrder) - Find the values common to both A and B
+ setdiff(A,B,setOrder) - Find the values in A that are not in B
+ ismember(A,B,setOrder) - Create a mask of A marking elements also in B
+ setxor(A,B,setOrder) - Find values of A and B not in both arrays
+ issorted(A) - Determine if array is already sorted

The subsequent data may be produced sorted, or left in the order
encountered.

## Example

```fortran
program demo_M_sets
use M_sets, only: &
& unique, intersect, union, setdiff, ismember, setxor, issorted
character(len=*),parameter :: all='(*(g0,1x))'
character(len=*),parameter :: nl=new_line('A')
integer, allocatable :: A(:)
integer, allocatable :: B(:)
integer, allocatable :: C(:)

A = [10, -10, 0, 1, 2, 3, 3, 2, 1, -10]
!
print all ,nl, &
'UNIQUE','Find the unique elements of vector A.' ,nl, &
'A=', A ,nl, &
'sorted=',unique(A) ,nl, &
'stable=',unique(A, setOrder='stable')

A=[5, 7, 1]
B=[3, 1, 1]
!
print all ,nl, &
'UNION', 'Find the union of vectors A and B.' ,nl, &
'A=', A ,nl, &
'B=', B ,nl, &
'sorted=',union(A, B, 'sorted') ,nl, &
'stable=',union(A, B, 'stable')

A=[7, 1, 7, 7, 4]
B=[7, 0, 4, 4, 0]
!
print all ,nl, &
'INTERSECT', 'Find the values common to both A and B.' ,nl, &
'A=', A ,nl, &
'B=', B ,nl, &
'sorted=',intersect(A, B) ,nl, &
'stable=',intersect(A, B, setOrder='stable')

A=[3, 6, 2, 1, 5, 1, 1]
B=[2, 4, 6]
!
print all ,nl, &
'SETDIFF','Find the values in A that are not in B.' ,nl, &
'A=', A ,nl, &
'B=', B ,nl, &
'sorted=',setdiff(A, B, 'sorted') ,nl, &
'stable=',setdiff(A, B, 'stable')

A=[5,3,4,2]
B=[2,4,4,4,6,8]
!
print all ,nl, &
'ISMEMBER','Determine which elements of A are also in B.' ,nl, &
'A=', A ,nl, &
'B=', B ,nl, &
'in A and B=',ismember(A,B)

A=[5,1,3,3,3]
B=[4,1,2]
!
print all ,nl, &
'SETXOR' , &
'Find values of A and B not in their intersection.' ,nl, &
'A=', A ,nl, &
'B=', B ,nl, &
'sorted=',setxor(A,B) ,nl, &
'stable=',setxor(A,B,'stable')

A=[1,2,3,4,5]
B=[5,4,3,2,1]
!
print all ,nl, &
'ISSSORTED' , &
'confirm whether array is sorted in ascending order or not' ,nl, &
'A=', A ,nl, &
'B=', B ,nl, &
'is A sorted?',issorted(A) ,nl, &
'is B sorted?',issorted(B)

end program demo_M_sets
```

Results:
```text
>
> UNIQUE Find the unique elements of vector A.
> A= 10 -10 0 1 2 3 3 2 1 -10
> sorted= -10 0 1 2 3 10
> stable= 10 -10 0 1 2 3
>
> UNION Find the union of vectors A and B.
> A= 5 7 1
> B= 3 1 1
> sorted= 1 3 5 7
> stable= 5 7 1 3
>
> INTERSECT Find the values common to both A and B.
> A= 7 1 7 7 4
> B= 7 0 4 4 0
> sorted= 4 7
> stable= 7 4
>
> SETDIFF Find the values in A that are not in B.
> A= 3 6 2 1 5 1 1
> B= 2 4 6
> sorted= 1 3 5
> stable= 3 1 5
>
> ISMEMBER Determine which elements of A are also in B.
> A= 5 3 4 2
> B= 2 4 4 4 6 8
> in A and B= 0 0 1 1
>
> SETXOR Find values of A and B not in their intersection.
> A= 5 1 3 3 3
> B= 4 1 2
> sorted= 2 3 4 5
> stable= 5 3 4 2
>
> ISSSORTED confirm whether array is sorted in ascending order or not
> A= 1 2 3 4 5
> B= 5 4 3 2 1
> is A sorted? 1
> is B sorted? 0
```

---
## Build and test with ![fpm](docs/images/fpm_logo.gif)

Download the github repository and build it with fpm ( as described at
[Fortran Package Manager](https://github.com/fortran-lang/fpm) )
```bash
git clone https://github.com/urbanjost/M_sets.git
cd M_sets
fpm build
```

or just list it as a dependency in your fpm.toml project file.

```toml
[dependencies]
M_sets = { git = "https://github.com/urbanjost/M_sets.git" }
```
---
## Documentation ![docs](docs/images/docs.gif)

The documentation for each procedure is included in the source.
That documentation is also available as a flat text file, HTML
documents, and man-pages.

### User
- A [text manual](https://urbanjost.github.io/M_sets/manual.txt)
contains all the procedure descriptions in a single flat ASCII
text file.

- [routines](https://urbanjost.github.io/M_sets/man3.html)
are also described in HTML form using the format of man-pages.

- For easier searching and printing Javascript is used to combine
all those HTML descriptions of the man-pages into a single
[book](https://urbanjost.github.io/M_sets/BOOK_M_sets.html).

- ![man-pages](docs/images/manpages.gif) are the de-facto standard
method of providing procedure descriptions on Unix, GNU/Linux,
OpenBSD, Cygwin, WLS, and other ULS (Unix-Like Systems)

Installation can vary depending on whether you are installing
personal copies or as an administrator, but man-pages are well suited
for any CLI user (Command-Line Interface):

+ [manpages.zip](https://urbanjost.github.io/M_sets/manpages.zip)
+ [manpages.tgz](https://urbanjost.github.io/M_sets/manpages.tgz)

- [CHANGELOG](docs/CHANGELOG.md) provides a history of significant changes
---
### Developer
- [ford(1) output](https://urbanjost.github.io/M_sets/fpm-ford/index.html).
- [doxygen(1) output](https://urbanjost.github.io/M_sets/doxygen_out/html/index.html).
- [github action status](docs/STATUS.md)
---

## References ![-](docs/images/ref.gif)

## See also ![-](docs/images/demos.gif)
* [M_orderpack](https://github.com/urbanjost/M_orderpack)
* [M_random](https://github.com/urbanjost/M_random)