How can I write code to hint to the JVM to use vector operations?

前端 未结 3 1828
耶瑟儿~
耶瑟儿~ 2021-02-04 02:46

Somewhat related question, and a year old: Do any JVM's JIT compilers generate code that uses vectorized floating point instructions?

Preface: I am trying to do this

3条回答
  •  余生分开走
    2021-02-04 03:37

    How can I..audio processing..pure java (no JNI to C++, no GPGPU work, etc...)..use vector operations (e.g. SSE2, AVX, etc...)

    Java is high level language (one instruction in Java generates many hardware instructions) which is by-design (e.g. garbage collector memory management) not suitable for tasks that manipulate high data volumes in real time.

    There are usually special pieces of hardware optimized for particular role (e.g. image processing or speech recognition) that many times utilize parallelization through several simplified processing pipelines.

    There are also special programming languages for this sort of tasks, mainly hardware description languages and assembly language.

    Even C++ (considered the fast language) will not automagically use some super optimized hardware operations for you. It may just inline one of several hand-crafted assembly language methods at certain places.

    So my answer is that there is "probably no way" to instruct JVM to use some hardware optimization for your code (e.g. SSE) and even if there was some then the Java language runtime would still have too many other factors that will slow-down your code.

    Use a low-level language designed for this task and link it to the Java for high-level logic.

    EDIT: adding some more info based on comments

    If you are convinced that high-level "write once run anywhere" language runtime definitely should also do lots of low level optimizations for you and turn automagically your high-level code into optimized low-level code then...the way JIT compiler optimizes depends on the implementation of the Java Virtual Machine. There are many of them.

    In case of Oracle JVM (HotSpot) you can start looking for your answer by downloading the source code, text SSE2 appears in following files:

    • openjdk/hotspot/src/cpu/x86/vm/assembler_x86.cpp
    • openjdk/hotspot/src/cpu/x86/vm/assembler_x86.hpp
    • openjdk/hotspot/src/cpu/x86/vm/c1_LIRGenerator_x86.cpp
    • openjdk/hotspot/src/cpu/x86/vm/c1_Runtime1_x86.cpp
    • openjdk/hotspot/src/cpu/x86/vm/sharedRuntime_x86_32.cpp
    • openjdk/hotspot/src/cpu/x86/vm/vm_version_x86.cpp
    • openjdk/hotspot/src/cpu/x86/vm/vm_version_x86.hpp
    • openjdk/hotspot/src/cpu/x86/vm/x86_32.ad
    • openjdk/hotspot/src/os_cpu/linux_x86/vm/os_linux_x86.cpp
    • openjdk/hotspot/src/share/vm/c1/c1_GraphBuilder.cpp
    • openjdk/hotspot/src/share/vm/c1/c1_LinearScan.cpp
    • openjdk/hotspot/src/share/vm/runtime/globals.hpp

    They're in C++ and assembly language so you will have to learn some low level languages to read them anyway.

    I would not hunt that deep even with +500 bounty. IMHO the question is wrong based on wrong assumptions

提交回复
热议问题