Skip to content

Basic Numeric Operations and Functions for Swift (Based on Accelerate Framework)

License

Notifications You must be signed in to change notification settings

dboyliao/NumSwift

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

72 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Numeric Operations for Swift

This project is just a simple practice on Swift and Accelerate framework. The swift files contain some basic function used in numeric computation. The main functionality is build upon Accelearate framework which leaverages SIMD of the CPU, which make the codes run faster than native Swift code.

I am a big fan of python. In this project, you can find many of the functions mimic the API from numpy which is a popular package for scientific computation.

I hope you enjoy this package. Cheers.

Dependency

  • Accelerate framework
  • Foundation framework

Testing

First, change working directory to NumSwift.

Setup Testing Environment

We use numpy (python package for numeric computation) as reference. Please setup the python environment by following steps:

  • Instll python and virtualenv.
    • See this guide for detail of virtualenv
  • Activate a testing virtual environment.
    virtualenv venv_test
    source venv_test/bin/activate
    
  • Install required python packages
    • run pip install -r requirements.txt

You are ready to go!

Running Tests for Swift

  • Run make test-osx on Mac OSX.

Build

Importable Module

  • change working directory to NumSwift
  • Run make module
  • You will see a directory named NumSwiftModule
    • There are three files in that directory: NumSwift.swiftmodule, NumSwift.swiftdoc and libNumSwift.dylib
  • Include files generated in NumSwiftModule in you Xcode Project.
    • If you hate Xcode just like me, you can use swiftc instead with flags -I and -L
    • ex: Suppose you have a main.swift and import NumSwift in it, you can run xcrun -sdk macosx swiftc -I /path/to/NumSwiftModule -L /path/to/NumSwiftModule -lNumSwift -o main.

Importable Framework

  • Open NumSwift.xcodeproj under NumSwift/NumSwift/ directory.
  • Press Build.
  • You should be able to see NumSwift.framework under NumSwift/NumSwift/. Drag the framework file to any project you'd like to use it.
  • You should be able to import NumSwift in your project.

References

Accelerate Framework

Fourier Transform

  • DFT v.s FFT
  • vDSP Guide - DFT
    • That is why we use vDSP_DFT_XXX rather than vDSP_fft_XXX.
    • The header file which states you should prefer DFT over fft is located in /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.11.sdk/System/Library/Frameworks/Kernel.framework/Versions/Current/Headers/vecLib on my computer. Go see it for yourself.

Matrix

Licence

MIT

About

Basic Numeric Operations and Functions for Swift (Based on Accelerate Framework)

Resources

License

Stars

Watchers

Forks

Packages

No packages published